]> gcc.gnu.org Git - gcc.git/blame - gcc/ChangeLog
* reload.c: Revert 2003-01-31 change.
[gcc.git] / gcc / ChangeLog
CommitLineData
112f7223
UW
12003-02-01 Ulrich Weigand <uweigand@de.ibm.com>
2
3 * reload.c: Revert 2003-01-31 change.
4
434c87d4
JH
5Sat Feb 1 14:14:40 CET 2003 Jan Hubicka <jh@suse.cz>
6
7 * combine.c (combine_simplify_rtx): Use reversed_comparison_code_parts.
8
271bd540
RS
92003-02-01 Richard Sandiford <rsandifo@redhat.com>
10
11 * flags.h (flag_volatile): Remove declaration.
12 (flag_volatile_global, flag_volatile_static): Likewise.
13 * c-typeck.c (build_indirect_ref): Don't check flag_volatile.
14 * toplev.c (flag_volatile): Remove definition.
15 (flag_volatile_global, flag_volatile_static): Likewise.
16 (f_options): Remove corresponding entries here.
17 * varasm.c (make_decl_rtl): Don't check flag_volatile_global
18 or flag_volatile_static.
19 * doc/invoke.texi: Remove documentation of -fvolatile,
20 -fvolatile-global and -fvolatile-static.
21
17e6098e
JDA
222003-01-31 John David Anglin <dave.anglin@nrc-cnrc.gc.ca>
23
24 * pa.c (pa_output_function_prologue, pa_output_function_epilogue): Move
25 updating of total_code_bytes from prologue to epilogue.
26
2f278625
UW
272003-01-31 Ulrich Weigand <uweigand@de.ibm.com>
28
29 * reload.c (find_reloads): Do not use the mode specified in the insn
30 pattern as reload mode for address operands. Do not generate optional
31 reloads for operands where a mandatory reload was already pushed.
32 Generate optional reloads only in the final pass though find_reloads.
33 (have_replacement_p): New function.
34
05c425a9
GP
352003-01-31 Gerald Pfeifer <pfeifer@dbai.tuwien.ac.at>
36
37 * doc/install.texi (Testing): Remove a reference to our obsolete
38 /testresults web pages and strip redundant information concerning
39 test results.
40 (Binaries): Refer to Microsoft Windows instead of listing all
41 possible variants.
42
b0c42aed
JH
43Sat Feb 1 00:28:30 CET 2003 Jan Hubicka <jh@suse.cz>
44
45 * loop.c (emit_prefetch_instructions): Do conversion at right place in
46 RTL chain.
47
48 * combine.c (simplify_set): Reverse order of ragumetns to
49 REG_CANNOT_CHANGE_MODE_P
50 * df.c (df_def_record_1): Likewise.
51 * recog.c (register_operand): Likewise.
52 * simplify-rtx.c (simplify_subreg): Likewise.
53 * hard-reg-set.h (REG_CANNOT_CHANGE_MODE_P): Update use of
54 CANNOT_CHANGE_MODE_CLASS.
55 * regclass.c (cannot_change_mode_set_regs, invalid_mode_change_p):
56 Likewise.
57 * reload.c (push_reload): Likewise.
58 * alpha.h (CANNOT_CHANGE_MODE_CLASS): Update definition.
59 * ia64.h (CANNOT_CHANGE_MODE_CLASS): Update definition.
60 * mips.h (CANNOT_CHANGE_MODE_CLASS): Update definition.
61 * mips-protos.h (mips_cannot_change_mode_class): Update prototype.
62 * mips.c (mips_cannot_change_mode_class): Update.
63 * pa64-regs.h (CANNOT_CHANGE_MODE_CLASS): Update definition.
64 * rs6000.h (CANNOT_CHANGE_MODE_CLASS): Update definition.
65 * s390.h (CANNOT_CHANGE_MODE_CLASS): Update definition.
66 * sh.h (CANNOT_CHANGE_MODE_CLASS): Update definition.
67 * sh-protos.h (sh_cannot_change_mode_class): Update prototype.
68 * sh.c (sh_cannot_change_mode_class): Update.
69 * i386.h (CANNOT_CHANGE_MODE_CLASS): New.
70 * tm.texi (CANNOT_CHANGE_MODE_CLASS): Update documentation.
71
1f61a15d
GK
722003-01-31 Geoffrey Keating <geoffk@apple.com>
73
74 * config/darwin.h (LINK_COMMAND_SPEC): Update for Nathan's recent
75 change to LINK_COMMAND_SPEC in gcc.c.
76
7c712dcc
LR
772003-01-31 Jan Hubicka <jh@suse.cz>
78
79 PR c/9506
80 * i386.c (override_options): Use DEFAULT_PCC_STRUCT_RETURN.
81
e137391e
JDA
822003-01-31 John David Anglin <dave.anglin@nrc-cnrc.gc.ca>
83
84 * pa32-regs.h (REGNO_REG_CLASS, REG_CLASS_FROM_LETTER): Delete
85 duplicated code.
86
1824b90d
NS
872003-01-31 Nathan Sidwell <nathan@codesourcery.com>
88
89 * tree.h (TYPE_BINFO_SIZE, TYPE_BINFO_SIZE_UNIT): Remove.
90 (BINFO_ELTS): New #define.
91 * stor-layout.c (finalize_record_size): Don't set them.
92 * cp/cp-tree.h (BINFO_SUBVTT_INDEX, BINFO_VPTR_INDEX,
93 BINFO_PRIMARY_BASE_OF): Use BINFO_ELTS.
94 (BINFO_LANG_ELTS): New #define.
95 * cp/tree.c (make_binfo): Use BINFO_LANG_ELTS.
96 * java/class.c (make_class): Use BINFO_ELTS.
97 (set_super_info): Likewse.
98 (add_interface_do): Likewise.
99 * objc/objc-act.c (start_class): Use BINFO_ELTS.
100
8f9a402c
DS
1012003-01-31 Danny Smith <dannysmith@users.sourceforge.net>
102
103 * timevar.c (getrusage): Don't ever declare if not HAVE_GETRUSAGE.
104 (times): Don't ever declare if not HAVE_TIMES.
105 (clock): Don't ever declare if not HAVE_CLOCK.
106
cdd1f01b
RH
1072003-01-30 Richard Henderson <rth@redhat.com>
108
109 * flow.c (update_life_info): Zap life info after cleanup_cfg.
110 (regno_uninitialized): Use correct live at function entry set.
111 (regno_clobbered_at_setjmp): Likewise.
112
113 * expr.c (store_expr): Promote all MEM intermediates to regs.
114
6bc82793
KH
1152003-01-30 Kazu Hirata <kazu@cs.umass.edu>
116
117 * config/arm/arm.c: Fix comment typos.
118 * config/arm/arm.h: Likewise.
119 * config/arm/netbsd-elf.h: Likewise.
120 * config/arm/netbsd.h: Likewise.
121
f099d360
GK
1222003-01-30 Geoffrey Keating <geoffk@apple.com>
123
124 * gengtype.c (struct walk_type_data): Add needs_cast_p.
125 (walk_type): Set needs_cast_p in walk_type_data.
126 (write_types_process_field): Supply casts when required to suppress
127 warnings.
128 (write_root): Cast gt_pch_n_S to suppress warning.
129 * Makefile.in: Remove -Wno-error from gtype-desc.o and c-decl.o.
f099d360
GK
130 * config/rs6000/rs6000.c (print_operand): Mask off high bits only
131 when they might exist.
132 * config/rs6000/t-rs6000: Remove -Wno-error from varasm.o,
133 insn-conditions.o, and rs6000.o.
134
52895e1a
RH
1352003-01-30 Richard Henderson <rth@redhat.com>
136
137 * ggc-page.c (G.context_depth_allocations): New.
138 (G.context_depth_collections): New.
139 (alloc_page): Set G.context_depth_allocations.
140 (ggc_collect): Set G.context_depth_collections.
141 (ggc_push_context): Limit to HOST_BITS_PER_LONG contexts.
142 (ggc_pop_context): Early exit for no allocations or collections.
143
c35c7e52
RH
1442003-01-30 Richard Henderson <rth@redhat.com>
145
146 * tree-inline.c (walk_tree): Streamline duplicate hash table lookup.
147
e43dd89d
RE
1482003-01-30 Richard Earnshaw <rearnsha@arm.com>
149
150 * arm.c (arm_compute_initial_elimination_offset): If optimizing for
151 size, the link register is always saved if any other register is
152 saved.
153
87a902e4
KH
1542003-01-30 Kazu Hirata <kazu@cs.umass.edu>
155
156 * config/h8300/h8300-protos.h: Update the prototype for
157 compute_plussi_cc.
158 (cpp_reader): Declare before it is used.
159 * config/h8300/h8300.c (compute_plussi_cc): Change the return
160 type to int.
161 * config/h8300/h8300.md (monitor_prologue): Call abort() if we
162 see an unknown H8 variant.
163
1642003-01-30 Ralf Corsepius <corsepiu@faw.uni-ulm.de>
0186a143
RC
165
166 PR target/9316
167 * config/rs6000/rtems.h: Add CPP_OS_DEFAULT_SPEC.
168 * config/rs6000/sysv4.h: Add CPP_OS_RTEMS_SPEC.
169 * config/rs6000/t-rtems: New file. multilib variants to match OS.
170 * config.gcc (powerpc-*-rtems*): Use rs6000/t-rtems instead of
171 rs6000/t-ppcgas so we get the desired multilibs.
172
f55d7103
NC
1732003-01-30 Nick Clifton <nickc@redhat.com>
174
175 * config/arm/arm.c (arm_output_epilogue): Update stack pointer
176 when popping saved IP register off the stack.
177
b6d08ca1
KH
1782003-01-30 Kazu Hirata <kazu@cs.umass.edu>
179
180 * config/rs6000/aix43.h: Fix comment typos.
181 * config/rs6000/aix51.h: Likewise.
182 * config/rs6000/aix52.h: Likewise.
183 * config/rs6000/altivec.h: Likewise.
184 * config/rs6000/rs6000.c: Likewise.
185 * config/rs6000/rs6000.h: Likewise.
186 * config/rs6000/rs6000.md: Likewise.
187 * config/rs6000/spe.md: Likewise.
188
14d22dd6
MM
1892003-01-29 Mark Mitchell <mark@codesourcery.com>
190
191 * c-common.c (builtin_define_float_constants): Define
192 __<TYPE>_HAS_INFINITY__ and __<TYPE>_HAS_QUIET_NAN__.
193
825db093
KH
1942003-01-30 Kazu Hirata <kazu@cs.umass.edu>
195
196 * config/sh/lib1funcs.asm: Fix comment typos.
197 * config/sh/linux.h: Likewise.
198 * config/sh/sh.c: Likewise.
199 * config/sh/sh.md: Likewise.
200
f1d5271a
LR
2012003-01-30 Loren James Rittle <ljrittle@acm.org>
202
203 * objc/Make-lang.in (objc-parse.y): Find c-parse.in in $(srcdir).
204
266a9ef1
AO
2052003-01-30 Alexandre Oliva <aoliva@redhat.com>
206
207 * config/fp-bit.h (__make_dp): Declare if TMODES.
208
0889116d
KH
2092003-01-29 Kazu Hirata <kazu@cs.umass.edu>
210
211 * config/h8300/h8300.h (PREDICATE_CODES): Add entries for
212 general_operand_src and general_operand_dst.
213
c8c99a68
DE
2142003-01-29 David Edelsohn <edelsohn@gnu.org>
215
216 * config/rs6000/rs6000.c (function_arg_pass_by_reference):
217 Return true for variable sized types.
218 (rs6000_va_arg): Handle variable sized types passed by reference
219 on non-SVR4 ABI.
220
ccf4d512
RE
2212003-01-29 Richard Earnshaw <rearnsha@arm.com>
222
223 * arm.c (arm_legtimize_address): New function.
224 * arm-protos.h (arm_legtimize_address): Add prototype.
225 * arm.h (ARM_LEGITIMIZE_ADDRESS): Use arm_legitimize_address.
226 (LEGITIMIZE_ADDRESS, THUMB_LEGITIMIZE_ADDRESS): Wrap with
227 do ... while (0)
228
0889116d 2292003-01-29 Joel Sherrill <joel@OARcorp.com>
0680c8fb 230
7429b411 231 PR bootstrap/9296
0680c8fb 232 * gthr-rtems.h: Define __GTHREAD_MUTEX_INIT. Apparently no code
7429b411 233 depended on it being defined until now.
0680c8fb 234
7429b411 2352003-01-29 Joel Sherrill <joel@OARcorp.com>
c934274a 236
7429b411 237 PR target/9295
c934274a
JS
238 * config/mips/rtems.h: Predefine __USE_INIT_FINI__ so generic
239 RTEMS code knows which C++ initialization style the toolset
7429b411 240 configuration is using.
c934274a 241
0889116d 2422003-01-29 Joel Sherrill <joel@OARcorp.com>
2e327e6e 243
7429b411 244 PR bootstrap/9293
2e327e6e
JS
245 * config/m68k/t-crtstuff: Replace spaces with tabs, add
246 $(MULTILIB_CFLAGS) as compiler option and multilib crtbegin/end.o.
2e327e6e 247
0889116d 2482003-01-29 Joel Sherrill <joel@OARcorp.com>
64abe03e 249
7429b411 250 PR bootstrap/9292
64abe03e
JS
251 * config.gcc (hppa1.1-rtems): Did not include t-rtems nor enable
252 RTEMS threads.
253 * config/pa/rtems.h (LIB_SPEC): Use -N when linking.
64abe03e 254
2f12fb2b
NC
2552003-01-29 Nick Clifton <nickc@redhat.com>
256
257 * Makefile.in (c-parse.o): Locate source file in $(parsedir)
258 not $(srcdir).
259
cf0150b9
AH
2602003-01-29 Andrew Haley <aph@redhat.com>
261
262 * tree-inline.c (walk_tree): Add CHAR_TYPE.
263
9b74f3ea
JH
264Wed Jan 29 10:26:12 CET 2003 Jan Hubicka <jh@suse.cz>
265
266 * i386.md (subdi3_carry_rex64): Fix typo.
267
e150159c
SS
2682003-01-28 Stan Shebs <shebs@apple.com>
269
270 * coretypes.h (cpp_reader): Forward declare struct.
271 * c-pragma.h (cpp_reader): Remove forward declaration.
272 * hashtable.h (cpp_reader): Likewise.
273 * scan.h (cpp_reader): Likewise.
274 * tree.h (cpp_reader): Likewise.
275 * config/darwin-protos.h (cpp_reader): Likewise.
276 * config/arm/arm-protos.h (cpp_reader): Likewise.
277 * config/rs6000/rs6000-protos.h: Remove GCC_CPPLIB_H ifdef, use
278 struct cpp_reader in prototypes.
279
53b50ac1
CC
2802003-01-28 Christian Cornelssen <ccorn@cs.tu-berlin.de>
281
282 * doc/install.texi: Add documentation for installation into
283 tooldirs and with DESTDIR.
284
021aa6ed
RH
2852003-01-28 Richard Henderson <rth@redhat.com>
286
287 * config.gcc (ia64*-*-aix*): Remove.
288 * config/ia64/aix.h, config/ia64/t-aix: Remove file.
289 * config/ia64/unwind-aix.c: Remove file.
290
c1c1d123
AS
2912003-01-28 Andreas Schwab <schwab@suse.de>
292
293 * config/m68k/m68k.md (tablejump+2): Don't sign extend an address
294 register.
295 * config/m68k/apollo68.h (ASM_RETURN_CASE_JUMP): Likewise.
296 * config/m68k/coff.h (ASM_RETURN_CASE_JUMP): Likewise.
297 * config/m68k/linux.h (ASM_RETURN_CASE_JUMP): Likewise.
298 * config/m68k/m68kelf.h (ASM_RETURN_CASE_JUMP): Likewise.
299 * config/m68k/mot3300.h (ASM_RETURN_CASE_JUMP): Likewise.
300 * config/m68k/netbsd-elf.h (ASM_RETURN_CASE_JUMP): Likewise.
301 * config/m68k/pbb.h (ASM_RETURN_CASE_JUMP): Likewise.
302
6d09ef27
RS
3032003-01-28 Richard Sandiford <rsandifo@redhat.com>
304
305 * combine.c (nonzero_bits): Fix check for negative divide operands.
306
1e1bd14e
RH
3072003-01-28 Richard Henderson <rth@redhat.com>
308
309 * config/ia64/ia64.c (ia64_rwreloc_section_type_flags): New.
310 * config/ia64/hpux.h (TARGET_SECTION_TYPE_FLAGS): New.
311
e37135f7
RH
3122003-01-28 Richard Henderson <rth@redhat.com>
313
314 * cse.c (find_best_addr): Kill !ADDRESS_COST code.
315
75642f32
RH
316 * config/cris/cris.c (cris_address_cost): Make static.
317 (TARGET_RTX_COSTS, TARGET_ADDRESS_COST): New.
318 * config/cris/cris.h (ADDRESS_COST): Remove.
319 * config/cris/cris-protos.h: Update.
320
e37135f7 3212003-01-23 Mike Stump <mrs@apple.com>
1f80c9ef
MS
322
323 * regclass.c (init_reg_autoinc): New function.
324 (regclass): Move initialization of forbidden_inc_dec_class from
325 here...
326 (init_regs): to here. Avoids reinitialization for each function,
327 saving compilation time.
328
9fbd3e41
JM
3292003-01-28 Jason Merrill <jason@redhat.com>
330
331 * cpplib.h (struct cpp_options): Add warn_deprecated field.
332 * cppinit.c (cpp_create_reader): Turn it on by default.
333 * c-opts.c (c_common_decode_option): Set it.
334 * cpplib.c (do_pragma_once): Only complain about #pragma once
335 if warn_deprecated is set.
336
fe352c29 3372003-01-28 Dale Johannesen <dalej@apple.com>
9fbd3e41 338
1e1bd14e
RH
339 * emit-rtl.c (const_double_htab_hash): Use mode in the hash.
340 * loop.c (scan_loop): Move movables on -Os rich-register targets.
341 * config/rs6000/rs6000.md (sibcall*): Use match_operand for LR.
fe352c29 342
dcefdf67
RH
3432003-01-28 Richard Henderson <rth@redhat.com>
344
345 * target.h (targetm.address_cost): New.
346 * target-def.h (TARGET_ADDRESS_COST): New.
347 (TARGET_RTX_COSTS): Uncomment. Oops.
348 * cse.c (address_cost): Use new target hook.
349 (default_address_cost): New.
350 * output.h (default_address_cost): Declare.
351 * hooks.c (hook_int_rtx_0): New.
352 * hooks.h (hook_int_rtx_0): Declare.
353 * loop.c (combine_givs_p): Remove if 0 code.
354 * system.h (ADDRESS_COST): Poison.
355
356 * config/alpha/alpha.c, config/alpha/alpha.h, config/d30v/d30v.c,
357 config/d30v/d30v.h, config/ia64/ia64.c, config/ia64/ia64.h,
358 config/m32r/m32r.c, config/m32r/m32r.h, config/mcore/mcore.c,
359 config/mcore/mcore.h, config/mmix/mmix.c, config/mmix/mmix.h,
360 config/rs6000/rs6000.c, config/rs6000/rs6000.h, config/sparc/sparc.c,
361 config/sparc/sparc.h, config/v850/v850.c, config/v850/v850.h,
362 config/xtensa/xtensa.c, config/xtensa/xtensa.h
363 (TARGET_ADDRESS_COST): Define as hook_int_rtx_0.
364 (ADDRESS_COST): Remove.
365
366 * config/arc/arc-protos.h, config/arc/arc.c, config/arc/arc.h,
367 config/avr/avr-protos.h, config/avr/avr.c, config/avr/avr.h,
368 config/c4x/c4x-protos.h, config/c4x/c4x.c, config/c4x/c4x.h,
369 config/dsp16xx/dsp16xx-protos.h, config/dsp16xx/dsp16xx.c,
370 config/dsp16xx/dsp16xx.h, config/i386/i386-protos.h,
371 config/i386/i386.c, config/i386/i386.h, config/i960/i960-protos.h,
372 config/i960/i960.c, config/i960/i960.h, config/ip2k/ip2k-protos.h,
373 config/ip2k/ip2k.c, config/ip2k/ip2k.h, config/mips/mips-protos.h,
374 config/mips/mips.c, config/mips/mips.h,
375 config/m68hc11/m68hc11-protos.h, config/m68hc11/m68hc11.c,
376 config/m68hc11/m68hc11.h, config/ns32k/ns32k-protos.h,
377 config/ns32k/ns32k.c, config/ns32k/ns32k.h, config/pa/pa-protos.h,
378 config/pa/pa.c, config/pa/pa.h, config/s390/s390-protos.h,
379 config/s390/s390.c, config/s390/s390.h, config/vax/vax-protos.h,
380 config/vax/vax.c, config/vax/vax.h
381 (foo_address_cost): Make static.
382 (TARGET_ADDRESS_COST): New.
383 (ADDRESS_COST): Remove.
384
385 * config/arm/arm.h, config/arm/arm.c, config/m88k/m88k.h,
386 config/m88k/m88k.c, config/romp/romp.h, config/romp/romp.c,
387 config/sh/sh.c, config/sh/sh.h, config/stormy16/stormy16.c,
388 config/stormy16/stormy16.h
389 (ADDRESS_COST): Move code ...
390 (foo_address_cost): ... here.
391 (TARGET_ADDRESS_COST): New.
392
393 * config/m32r/m32r.c (m32r_address_cost): Remove.
394 * config/m32r/m32r-protos.h: Update.
395
396 * config/mmix/mmix.c (mmix_address_cost): Remove.
397 * config/mmix/mmix-protos.h: Update.
398
399 * config/mn10300/mn10300.c (mn10300_address_cost_1): Rename from
400 mn10300_address_cost; move unsig allocation ...
401 (mn10300_address_cost): ... here.
402 (TARGET_ADDRESS_COST): New.
403 * config/mn10300/mn10300-protos.h: Update.
404 * config/mn10300/mn10300.h (ADDRESS_COST): Remove.
405
75642f32
RH
406 * doc/tm.texi: Update.
407
58fb7809
VM
4082003-01-28 Vladimir Makarov <vmakarov@redhat.com>
409
410 * haifa-sched.c (schedule_insn): Return necessary cycle advance
411 after issuing the insn.
412 (rank_for_schedule): Make a insn with /S the highest priority
413 insn.
414 (move_insn): Ignore schedule groups. Clear SCHED_GROUP_P.
415 (choose_ready): Check SCHED_GROUP_P.
416 (schedule_block): Advance cycle after issuing insn if it is
417 necessary. Don't reorder insns if there is an insn with /S.
418 (set_priorities): Ignore schedule groups.
419
420 * sched-deps.c (remove_dependence, group_leader): Remove the
421 functions.
422 (add_dependence): Ignore schedule groups.
423 (set_sched_group_p): Don't make copy of dependencies from previous
424 insn of the schedule group. Add anti-dependency to the previous
425 insn of the schedule group.
426 (compute_forward_dependences): Ignore schedule groups.
427
428 * sched-ebb.c (init_ready_list): Ignore schedule groups.
429
430 * sched-rgn.c (init_ready_list): Ditto.
431 (can_schedule_ready_p): Ditto.
432
371c988b
VM
4332003-01-28 Vladimir Makarov <vmakarov@redhat.com>
434
435 * config/i386/i386.md (*movsi_1): Use movdqa to move one xmm
436 register to another one.
437
40cdfd5a
RH
4382003-01-28 Richard Henderson <rth@redhat.com>
439
440 * calls.c (default_must_pass_in_stack): Fix typo in !type case.
441
a77b7e32
RS
4422003-01-28 Roger Sayle <roger@eyesopen.com>
443
444 * cse.c (cse_insn): Avoid redundant REG_EQUAL notes.
445
3620944c
RS
4462003-01-28 Richard Sandiford <rsandifo@redhat.com>
447
448 * config/sh/sh.h (CLASS_MAX_NREGS): If TARGET_SHMEDIA, and the given
449 class contains a floating-point register, return the size of the
450 mode in half words.
451
e6e81735
JH
452Tue Jan 28 12:15:13 CET 2003 Jan Hubicka <jh@suse.cz>
453
454 * i386.c (ix86_carry_flag_operator): New predicate.
455 (fcmov_operator): Fix whitespace.
456 (ix86_expand_carry_flag_compare): Deal with floating point.
457 (ix86_expand_int_movcc): Deal with fp; update insn expansion
458 (ix86_expand_int_addcc): Likewise.
459 (ix86_expand_strlensi_unroll_1): likewsie.
460 * i386.h (PREDICATE_CODES): Add ix86_carry_flag_operator.
461 * i386.md (add?i_carry_rex64): Use new predicate.
462 (sub?i3_carry_rex64): Likewise.
463 (x86_mov?icc_0_m1*): Likewise.
464
43196589
AS
4652003-01-28 Andreas Schwab <schwab@suse.de>
466
32214c32
AS
467 * cfgloopmanip.c (create_preheader): Initialize src to avoid
468 warning.
469
470 * expmed.c (emit_store_flag): Fix cast to avoid sign
471 comparison warning.
472
43196589
AS
473 * combine.c (force_to_mode): Add cast to fix warning when
474 STORE_FLAG_VALUE is negative.
475
3c50106f
RH
4762003-01-27 Richard Henderson <rth@redhat.com>
477
478 * Makefile.in (cse.o): Depend on TARGET_H.
479 * cse.c (rtx_cost): Use targetm.rtx_costs.
480 * system.h (CONST_COSTS RTX_COSTS DEFAULT_RTX_COSTS): Poison.
481 * doc/tm.texi: Update.
482
483 * target.h (targetm.rtx_costs): New.
484 * target-def.h (TARGET_RTX_COSTS): New.
485 * hooks.c (hook_bool_rtx_int_int_intp_false): New.
486 * hooks.h: Update.
487
488 * config/alpha/alpha.c (alpha_rtx_cost_data): New.
489 (alpha_rtx_costs, TARGET_RTX_COSTS): New.
490 * config/alpha/alpha.h (PROCESSOR_MAX): New.
491 (CONST_COSTS, RTX_COSTS): Remove.
492
493 * config/arc/arc.c, config/arc/arc.h, config/c4x/c4x.c,
494 config/c4x/c4x.h, config/cris/cris.c, config/cris/cris.h,
495 config/d30v/d30v.c, config/d30v/d30v.h, config/dsp16xx/dsp16xx.c,
496 config/dsp16xx/dsp16xx.h, config/frv/frv.c, config/frv/frv.h,
497 config/h8300/h8300.c, config/h8300/h8300.h, config/i370/i370.c,
498 config/i370/i370.h, config/i386/i386.c, config/i386/i386.h,
499 config/i960/i960.c, config/i960/i960.h, config/ia64/ia64.c,
500 config/ia64/ia64.h, config/m32r/m32r.c, config/m32r/m32r.h,
501 config/m68k/m68k.c, config/m68k/m68k.h, config/m88k/m88k.c,
502 config/m88k/m88k.h, config/mcore/mcore.c, config/mcore/mcore.h,
503 config/mips/mips.c, config/mips/mips.h, config/mn10200/mn10200.c,
504 config/mn10200/mn10200.h, config/mn10300/mn10300.c,
505 config/mn10300/mn10300.h, config/ns32k/ns32k.c, config/ns32k/ns32k.h,
506 config/pa/pa.c, config/pa/pa.h, config/pdp11/pdp11.c,
507 config/pdp11/pdp11.h, config/romp/romp.c, config/romp/romp.h,
508 config/rs6000/rs6000.c, config/rs6000/rs6000.h, config/s390/s390.c,
509 config/s390/s390.h, config/sh/sh.c, config/sh/sh.h,
510 config/stormy16/stormy16.c, config/stormy16/stormy16.h,
511 config/v850/v850.c, config/v850/v850.h,
512 config/xtensa/xtensa.c, config/xtensa/xtensa.h
513 (CONST_COSTS, RTX_COSTS): Move code ...
514 (foo_rtx_costs, TARGET_RTX_COSTS): ... here.
515
516 * config/arm/arm.c (arm_rtx_costs_1): Rename from arm_rtx_costs.
517 (arm_rtx_costs, TARGET_RTX_COSTS): New.
518 * config/arm/arm-protos.h: Update.
519 * config/arm/arm.h (DEFAULT_RTX_COSTS): Remove.
520
521 * config/avr/avr.h (CONST_COSTS): Move code ...
522 * config/avr/avr.c (avr_rtx_costs): ... here.
523 (default_rtx_costs): Make static.
524 * config/avr/avr-protos.h: Update.
525
526 * config/h8300/h8300.c (const_costs): Make static.
527 (h8300_and_costs, h8300_shift_costs): Likewise.
528 * config/h8300/h8300-protos.h: Update.
529
530 * config/ip2k/ip2k.h (DEFAULT_RTX_COSTS): Remove.
531 (CONST_COSTS): Move code ...
532 * config/ip2k/ip2k.c (ip2k_rtx_costs): ... here. Rename from
533 default_rtx_costs; update for signature change.
534 * config/ip2k/ip2k-protos.h: Update.
535
536 * config/m68hc11/m68hc11.h (RTX_COSTS): Remove.
537 (CONST_COSTS): Move code ...
538 * config/m68hc11/m68hc11.c (m68hc11_rtx_costs): ... here.
539 (TARGET_RTX_COSTS): New.
540 (m68hc11_rtx_costs_1): Rename from m68hc11_rtx_costs; make static.
541 * config/m68hc11/m68hc11-protos.h: Update.
542
543 * config/m68k/m68k.c (const_int_cost): Make static.
544 * config/m68k/m68k-protos.h: Update.
545
546 * config/mcore/mcore.c (mcore_const_costs): Make static.
547 (mcore_and_cost, mcore_ior_cost): Likewise.
548 * config/mcore/mcore-protos.h: Update.
549
550 * config/mmix/mmix.c (mmix_rtx_costs, TARGET_RTX_COSTS): New.
551 (mmix_rtx_cost_recalculated): Remove.
552 * config/mmix/mmix.h (DEFAULT_RTX_COSTS): Remove.
553 * config/mmix/mmix-protos.h: Update.
554
555 * config/sh/sh.c (shiftcosts): Make static.
556 (addsubcosts, andcosts, multcosts): Likewise.
557 * config/sh/sh-protos.h: Update.
558
559 * config/sparc/sparc.c (TARGET_RTX_COSTS): New.
560 (sparc_rtx_costs): Make static; update for change in signature.
561 * config/sparc/sparc.h (RTX_COSTS_CASES, RTX_COSTS): Remove.
562 * config/sparc/sparc-protos.h: Update.
563
564 * config/v850/v850.c (const_costs): Make static.
565 * config/v850/v850-protos.h: Update.
566
567 * config/vax/vax.h (RTX_COSTS): Remove.
568 (CONST_COSTS): Move code ...
569 * config/vax/vax.c (vax_rtx_costs_1): ... here; rename
570 from vax_rtx_cost.
571 (vax_rtx_costs, TARGET_RTX_COSTS): New.
572
b9962e0a
RH
5732003-01-27 Richard Henderson <rth@redhat.com>
574
575 * config/vax/vax.h (ASM_OUTPUT_MI_THUNK): Remove. Really.
5ca98980 576 * config/vax/vax-protos.h: Update. Really.
b9962e0a 577
8a381273
AO
5782003-01-28 Alexandre Oliva <aoliva@redhat.com>
579
580 * config/mips/mips.h (UNITS_PER_HWFPVALUE): Renamed from...
581 (UNITS_PER_FPVALUE): Defined as the width of a long double, or
582 zero if no hardware floating point.
583 (LONG_DUBLE_TYPE_SIZE): Set to 128 on N32 and N64.
584 (MAX_FIXED_MODE_SIZE): Define to LONG_DOUBLE_TYPE_SIZE.
585 (LIBGCC2_LONG_DOUBLE_TYPE_SIZE): Define.
586 (BIGGEST_ALIGNMENT): Same as LONG_DOUBLE_TYPE_SIZE.
587 (FUNCTION_VALUE_REGNO_P): Set for FP_RETURN+2 on N32 and N64.
588 * config/mips/mips.c (mips_arg_info): Pass TFmode values in
589 even FP registers on N32 and N64.
590 (mips_setup_incoming_varargs): Use UNITS_PER_HWFPVALUE.
591 (mips_va_start): Adjust alignment of ARG_POINTER_REGNUM.
592 (mips_va_arg): Use UNITS_PER_HWFPVALUE. Impose additional
593 even-register-like alignment to 128-bit arguments.
594 (save_restore_insns): Use UNITS_PER_HWFPVALUE.
595 (mips_function_value): Likewise. Return TFmode in $f0 and $f2
596 on N32 or N64.
597 * config/mips/_tilib.c (__negti2, __ashlti3, __lshrti3): New.
598 * config/mips/t-iris6 (LIB2FUNCS_EXTRA): Add _tilib.c.
599 (TPBIT): Set to tp-bit.c.
600 (tp-bit.c): Create out of fp-bit.c.
601
820e01be
GDR
6022003-01-28 Gabriel Dos Reis <gdr@integrable-solutions.net>
603
604 * c-parse.in: Remove '%expect 32' directive in objc mode.
605
23af32e6
NS
6062003-01-27 Nathan Sidwell <nathan@codesourcery.com>
607
608 * Makefile.in (LIB2FUNCS_ST): Remove _gcov.
609 (LIBGCOV): New variable.
610 (libgcc.mk): Add LIBGCOV.
611 (LIBGCC_DEPS): Add libgcov.c.
612 (libgcov.a): New target.
613 (clean): Remove libgcov.a.
614 (install-libgcc): Do libgcov too.
615 (stage1-start, stage2-start, stage3-start, stage4-start): Deal
616 with libgcov.a.
617 * libgcc2.c (L_gcov): Move into ...
618 * libgcov.c: ... here. New file.
619 * mklibgcc.in: Add libgcov rules.
620 * gcc.c (LINK_COMMAND_SPEC): Add -lgcov when profiling.
621
622 * doc/invoke.texi (profile-arcs, test-coverage): Update and
623 clarify.
624
625 * profile.c (index_counts_file): Remove duplicate check for open file.
626
9fe42917 6272003-01-27 Jerry Quinn <jlquinn@optonline.net>
d4463dfc
JQ
628
629 * gcc/doc/invoke.texi (Optimization Options): Group together
630 optional and experimental flags. Move trapv and bounds-check
95fcd0ab 631 out of this section. Group floating point flags together.
d4463dfc
JQ
632 (Code Gen Options): Move trapv and bounds-check to here.
633
244d05fb
JZ
6342003-01-27 Josef Zlomek <zlomekj@suse.cz>
635
636 * gcse.c (constprop_register): Check NEXT_INSN (insn) != NULL.
637
c552c146
RE
6382003-01-27 Richard Earnshaw <rearnsha@arm.com>
639
640 PR optimization/9090
641 * function.c (purge_addressof_1): After pushing an addressed register
642 onto the stack, simplify the result.
643
90a21764
VR
6442003-01-27 Volker Reichelt <reichelt@igpm.rwth-aachen.de>
645
646 * doc/extend.texi: Fix typo.
647
9a376494
VR
6482003-01-27 Volker Reichelt <reichelt@igpm.rwth-aachen.de>
649
650 * doc/cppopts.texi: Fix typo.
651 * doc/objc.texi: Likewise.
652 * doc/passes.texi: Likewise.
653
f004e5f3
AO
6542003-01-27 Alexandre Oliva <aoliva@redhat.com>
655
656 * real.c (ibm_extended_format): Add 53 to minimum exponent.
657 (encode_ibm_extended): Adjust.
658
58c60e52
GDR
6592003-01-26 Gabriel Dos Reis <gdr@soliton.integrable-solutions.net>
660
661 * timevar.def (TV_OVERLOAD, TV_TEMPLATE_INSTANTIATION): New
662 timevar_id enumerations.
663
e869aa39
KH
6642003-01-26 Kazu Hirata <kazu@cs.umass.edu>
665
666 * combine.c: Fix formatting.
667
74fb4811
KH
6682003-01-26 Kazu Hirata <kazu@cs.umass.edu>
669
670 * doc/gccint.texi: Update the copyright.
671
3bcf1b13
KH
6722003-01-26 Kazu Hirata <kazu@cs.umass.edu>
673
674 * doc/cpp.texi: Fix typos.
675 * doc/extend.texi: Likewise.
676 * doc/gty.texi: Likewise.
677 * doc/install.texi: Likewise.
678 * doc/passes.texi: Likewise.
679 * doc/rtl.texi: Likewise.
680 * doc/tm.texi: Likewise.
681
9e4f94de
KH
6822003-01-26 Kazu Hirata <kazu@cs.umass.edu>
683
684 * config/ia64/fde-glibc.c: Fix comment typos.
685 * config/ia64/hpux.h: Likewise.
686 * config/ia64/ia64.c: Likewise.
687 * config/ia64/ia64.h: Likewise.
688 * config/ia64/unwind-ia64.c: Likewise.
689
4aae8a9a
KH
6902003-01-26 Kazu Hirata <kazu@cs.umass.edu>
691
692 * config/i386/i386-modes.def: Fix comment typos.
693 * config/i386/i386.c: Likewise.
694 * config/i386/i386.md: Likewise.
695
35d8c8e2
SB
6962003-01-26 Steven Bosscher <s.bosscher@student.tudelft.nl>
697
698 * config/avr/avr.h, config/cris/aout.h, config/elfos.h,
699 config/i386/freebsd-aout.h, config/mips/iris6.h: Undefine
700 ASM_FINISH_DECLARE_OBJECT before defining it.
701 * toplev.c (rest_of_decl_compilation): Don't define
702 ASM_FINISH_DECLARE_OBJECT. Only use it if it is defined.
703 (rest_of_type_compilation): Don't ATTRIBUTE_UNUSED function
704 parameters for DWARF2 targets because they _are_ used.
705
ea976606
AO
7062003-01-26 Alexandre Oliva <aoliva@redhat.com>
707
b44cf3d9
AO
708 * fp-bit.h: Define macros for TFmode floating-point constants
709 in IBM-extended TFmode types.
710 (TMODES): Define if __LDBL_MANT_DIG__ has the newly-supported
711 widths.
712 * config/fp-bit.c (pack_d, unpack_d): Support IBM-extended
713 TFmode type.
714
ea976606
AO
715 * config/fp-bit.h: Define macros for TFmode floating-point
716 constants in IEEE quad TFmode type. Declare functions according
717 to L_ macros.
718 (TMODES): Define if __LDBL_MANT_DIG__ is 113.
719 (TFtype, TItype, UTItype): Define if TMODES is defined.
720 (MAX_UDI_INT, MAX_DI_INT, BITS_PER_DI): Likewise.
721 (F_T_BITOFF, D_T_BITOFF): Define.
722 (IMPLICIT_1, IMPLICIT_2): Cast constants to types that are
723 guaranteed to be wide enough.
724 * config/fp-bit.c: Check for L_ macros for tf functions.
725 (__thenan_tf): New.
726 (nan): Adjust.
727 (pack_d, unpack_d): Support IEEE 854 quad type.
728 (_fpmul_parts): Support TFmode. Compute exponent adjustment
729 from FRAC_NBITS, FRAC_BITS and NGARDS.
730 (usi_to_float): Cast constants to be shifted to fractype
731 instead of assuming long long is wide enough.
732 (sf_to_tf, df_to_tf, __make_tp, tf_to_df, tf_to_sf): New.
733
fd7fd61e
AJ
7342003-01-26 Andreas Jaeger <aj@suse.de>
735
736 * df.c: Remove prototype of unused function df_regno_rtl_debug.
737
8ae91fc0
AO
7382003-01-26 Alexandre Oliva <aoliva@redhat.com>
739
88e83acb
AO
740 * Makefile.in (FPBIT_FUNCS): Added _sf_to_tf.
741 (DBBIT_FUNCS): Added _df_to_tf.
742 (TPBIT_FUNCS): New.
743 (libgcc.mk): Pass TPBIT and TPBIT_FUNCS down.
744 (LIBGCC_DEPS): Added TPBIT.
745 * mklibgcc.in: Support TPBIT and TPBIT_FUNCS.
746
2cd622c3
AO
747 * optabs.c (expand_binop) <add, sub>: Return xtarget if we haven't
748 been able to move the result to target.
749
8ae91fc0
AO
750 * expr.c (emit_group_store): Initialize dst with CONST0_RTX
751 for the appropriate mode.
752
c3297561
AO
753 * calls.c (emit_library_call_value_1): Handle return values
754 in a PARALLEL.
755
187515f5
AO
756 * rtl.c (get_mode_alignment): Moved to...
757 * stor-layout.c: ... here.
758
6ebd2ef4
AO
759 * print-rtl.c (print_rtx): Don't print MEM details in
760 GENERATOR_FILEs.
761
7890e8f3
MH
7622003-01-26 Michael Hayes <mph@paradise.net.nz>
763
764 * df.h: Update comments, tidy formatting.
765 (DF_FORWARD, DF_REVERSE, DF_UNION, DF_INTERSECTION): Rename from FORWARD,
766 REVERSE, UNION, INTERSECTION. All uses updated.
767 (OLD_DF_INTERFACE): Remove.
768 (struct insn_info): Remove commented out insn field.
769 * df.c: Update comments, tidy formatting.
770 (df_def_table_realloc): Remove.
771
772
b820d2b8
AM
7732003-01-26 Alan Modra <amodra@bigpond.net.au>
774
775 * calls.c (save_fixed_argument_area): Tidy.
776 (restore_fixed_argument_area): Tidy. Set alignment of stack_area.
777 (expand_call): Comment typo fixes. Don't init low_to_save. Start
778 call chain loop at 1 if !try_tail_call. Formatting.
779 (emit_library_call_value_1): Don't init low_to_save or high_to_save.
780 Use save_fixed_argument_area and restore_fixed_argument_area.
781
42510de4
MH
7822003-01-26 Michael Hayes <m.hayes@elec.canterbury.ac.nz>
783
784 * df.c (df_uses_record): Handle CC0.
785
acf9fa5f
UW
7862003-01-25 Ulrich Weigand <uweigand@de.ibm.com>
787
1e1bd14e
RH
788 * reload.c (maybe_memory_address_p): New function.
789 (find_reloads_address): Use it instead of memory_address_p.
acf9fa5f 790
5a09edba
KK
7912003-01-25 Kaz Kojima <kkojima@gcc.gnu.org>
792
793 * final.c (shorten_branches): Align the address of code label
1e1bd14e 794 when computing initial lengths and addresses.
5a09edba 795
f5818c0c
KH
7962003-01-25 Kazu Hirata <kazu@cs.umass.edu>
797
798 * config/m68hc11/m68hc11.md: Fix a comment typo.
799
21ff35fb
AJ
8002003-01-25 Andreas Jaeger <aj@suse.de>
801
802 * config/i386/i386.c (x86_output_mi_thunk): Correct test for
803 TARGET_MACHO.
804
7821bfc7
RS
8052003-01-25 Roger Sayle <roger@eyesopen.com>
806
807 * gcse.c (bypass_last_basic_block): New global variable.
808 (bypass_block): Use redirect_edge_and_branch_force to redirect
809 fall-through edges. Use bypass_last_basic_block to determine
810 which blocks have valid PRE information.
811 (bypass_conditional_jumps): Initialize bypass_last_basic_block.
812
5f0bea72
JH
813Sat Jan 25 22:31:59 CET 2003 Jan Hubicka <jh@suse.cz>
814
815 * gcse.c (local_cprop_pass): Update reg_sets table when needed.
816
1649d92f
JH
817Sat Jan 25 21:04:33 CET 2003 Jan Hubicka <jh@suse.cz>
818 Eric Botcazou <ebotcazou@libertysurf.fr>
819 PR opt/8492
820 * gcse.c (one_cprop_pass): Delete unreachable blocks.
821
6ca86a1a
RH
8222003-01-25 Richard Henderson <rth@redhat.com>
823
824 * config/ia64/ia64.c (ia64_rwreloc_select_rtx_section): Rename
825 from ia64_aix_select_rtx_section.
826 (ia64_rwreloc_select_section): Simlarly; use default*_1 function
827 instead of saving and restoring flag_pic.
828 (ia64_rwreloc_unique_section): Similarly.
829 * config/ia64/aix.h (TARGET_ASM_SELECT_SECTION,
830 TARGET_ASM_UNIQUE_SECTION, TARGET_ASM_SELECT_RTX_SECTION): Update.
831 * config/ia64/hpux.h (TARGET_ASM_SELECT_SECTION,
832 TARGET_ASM_UNIQUE_SECTION, TARGET_ASM_SELECT_RTX_SECTION): New.
833
aa2fb4dd
KH
8342003-01-25 Kazu Hirata <kazu@cs.umass.edu>
835
836 * config/h8300/h8300.c (h8300_shift_needs_scratch_p): Update a
837 comment.
838
1125849a
RH
8392002-01-25 Richard Henderson <rth@redhat.com>
840
841 * config/m68k/m68k-none.h (ASM_SPEC): Adjust inter-option spacing.
842
3900a23b
KC
8432002-01-25 Kelley Cook <kelleycook@comcast.net>
844
845 * ggc-simple.c (debug_ggc_tree): Add PTR cast.
846
72e42e26
SB
8472003-01-25 Segher Boessenkool <segher@koffie.nl>
848
849 * bitmap.h (BITMAP_WORD): New typedef: fundamental storage
850 type for bitmaps. Use unsigned long.
851 (nBITMAP_WORD_BITS): New macro.
852 (BITMAP_WORD_BITS): New macro.
853 (rest of file): Use it.
854 * bitmap.c: Use it.
855
8324663f
RH
8562003-01-25 Richard Henderson <rth@redhat.com>
857
858 2002-02-19 Robert Lipe <robertlipe@usa.net>
859 * config/i386/t-sco5gas: (CRTSTUFF_T_CFLAGS_S): Delete -mcoff.
860
2adc9b0f
RS
8612002-01-25 Roger Sayle <roger@eyesopen.com>
862
863 * builtins.c (purge_builtin_constant_p): Scan insn stream
864 sequentially rather than by basic block.
865 * function.c (purge_addressof): Simplify test with INSN_P.
866
ad487c38
KH
8672003-01-25 Kazu Hirata <kazu@cs.umass.edu>
868
8324663f 869 * combine.c (simplify_comparison, case AND): Remove a redundant test.
ad487c38 870
07d9b20d
RS
8712002-01-25 Roger Sayle <roger@eyesopen.com>
872
873 * function.h (struct function): New field calls_constant_p.
874 (current_function_calls_constant_p): New macro for above.
875 * function.c (prepare_function_start): Initialize calls_eh_return
876 and calls_constant_p.
877 * builtins.c (expand_builtin_constant_p): Set calls_constant_p.
878 * toplev.c (rest_of_compilation): Only call purge_builtin_constant_p
879 when the current_function_calls_constant_p.
880 * integrate.c (expand_inline_function): Set calls_constant_p if
881 the function being inlined has calls_constant_p set.
882
41559112
RS
8832002-01-25 Roger Sayle <roger@eyesopen.com>
884
885 * cse.c (fold_rtx): Instantiate CONSTANT_P_RTX to 0 when not
886 optimizing, even if flag_gcse is true.
887 * toplev.c (rest_of_compilation): purge_builtin_constant_p
888 only needs to be called when "optimize > 0 && flag_gcse".
889
9bb231fd
RS
8902003-01-25 Roger Sayle <roger@eyesopen.com>
891
892 * stmt.c (emit_case_bit_tests): New routine to implement suitable
893 switch statements using the equivalent of "if ((1<<x) & cst) ... ".
894 (case_bit_test_cmp): New comparison function for "qsort" to order
895 case_bit_tests by decreasing number of destination nodes.
896 (lshift_cheap_p): New function to determine if "1 << x" is cheap.
897 (expand_end_case_type): Use emit_case_bit_tests to implement
898 suitable switch statments.
899 (CASE_USE_BIT_TESTS): New target macro to disable the above.
900 * Makefile.in (stmt.o): Add dependency on optab.h.
901 * doc/tm.texi (CASE_USE_BIT_TESTS): Document new target macro.
902
a073323c
AS
9032003-01-23 Andreas Schwab <schwab@suse.de>
904
905 * config/ia64/crtend.asm [HAVE_INITFINI_ARRAY]: Make
906 __do_global_ctors_aux hidden global and don't put it in
907 .init_array.
908 * config/ia64/crtbegin.asm [HAVE_INITFINI_ARRAY]: Put it here
909 instead so that it comes first.
910
36ddc6b0
JH
911Sat Jan 25 16:11:22 CET 2003 Jan Hubicka <jh@suse.cz>
912
913 * df.c (read_modify_subreg_p): When osize == UNITS_PER_WORD,
914 subreg is read/modify.
915
26771da7
JH
916Sat Jan 25 15:55:08 CET 2003 Jan Hubicka <jh@suse.cz>
917
918 * i386.c (ix86_expand_movstr, ix86_expand_clrstr): Consistently
919 do libcall for large blocks.
920 * i386.md (comi patterns): Set type to ssecomi.
921 (sse2_unpck?pd): Fix mode of vec_select.
922
923 * cse.c: Include except.h
924 (cse_set_around_loop): Do not create new basic blocks.
925 * Makefile.in (cse.o): Add dependnecy on except.h
926
27a6aa72
JH
927Sat Jan 25 12:05:17 CET 2003 Jan Hubicka <jh@suse.cz>
928
929 * builtins.c (fold_trunc_transparent_mathfn): New function.
930 (fold_builtin): Use it.
931 * convert.c (convert_to_real): Re-enable code to convert
932 math functions; add support for floor familly functions.
933
cd68f4e4
ZD
9342003-01-25 Zdenek Dvorak <rakdver@atrey.karlin.mff.cuni.cz>
935
936 * Makefile.in (cfgloop.o, cfgloopanal.o, cfgloopmanip.o): Add
937 dependencies on coretypes.h and $(TM_H).
938
67945f2e
JH
939Sat Jan 25 11:10:03 CET 2003 Jan Hubicka <jh@suse.cz>
940
941 * builtins.c (fold_trunc_transparent_mathfn): Undo accidental commit.
942
095fa594
SH
9432002-01-24 Stuart Hastings <stuart@apple.com>
944
08f0414b 945 * config/i386/i386.c (x86_output_mi_thunk): Add Darwin/x86 support.
095fa594 946
1e4c04e0
MH
9472003-01-25 Michael Hayes <m.hayes@elec.canterbury.ac.nz>
948
949 * config/c4x/c4x.md (UNSPEC_BU): New constants.
950 (UNSPEC_RPTS, UNSPEC_LSH, UNSPEC_CMPHI, UNSPEC_RCPF): Likewise.
951 (UNSPEC_RND, UNSPEC_RPTB_FILL, UNSPEC_LOADHF_INT): Likewise.
952 (UNSPEC_STOREHF_INT, UNSPEC_RSQRF, UNSPEC_LOADQF_INT): Likewise.
953 (UNSPEC_STOREQF_INT, UNSPEC_LDIV, UNSPEC_PUSH_ST): Likewise.
954 (UNSPEC_POP_ST, UNSPEC_PUSH_DP, UNSPEC_POP_DP): Likewise.
955 (UNSPEC_POPQI, UNSPEC_POPQF, UNSPEC_ANDN_ST): Likewise.
956 (UNSPEC_RPTB_INIT, UNSPEC_TOIEEE, UNSPEC_FRIEEE): Likewise.
957
a560d4d4
JH
958Fri Jan 24 23:44:12 CET 2003 Jan Hubicka <jh@suse.cz>
959
08f0414b 960 * emit-rtl.c (reg_attrs_htab): New static variable.
a560d4d4
JH
961 (reg_attrs_htab_hash, reg_attrs_htab_eq, get_reg_attrs): New static
962 functions.
963 (reg_rtx): Do not maintain regno_decl.
964 (gen_rtx_REG_offset, set_reg_attrs_from_mem, set_delc_rtx,
965 set_mem_attrs_from_reg): New global function.
966 (init_emit): Do not initialize regno_decl.
967 (init_emit_once): initialize reg_attrs_htab.
968 * final.c (alter_subreg): Do not replace REG by SUBREG.
969 (gen_mem_expr_from_op): Improve output.
970 (output_asm_operands): Likewise.
971 * function.c (assign_params): Do not set REGNO_DECL.
972 * function.h (struct function): Kill regno_decl.
973 (REGNO_DECL): Kill.
974 * gengtype.c (adjust_field_rtx_def): Handle new field of reg.
975 * print_rtl.c (print_rtx): Output REG information.
976 * regclass.c (reg_scan_mark_refs): Update attrs.
977 * reload1.c (alter_reg): Likewise.
978 * simplify_rtx.c (simplify_subreg): Likewise.
979 * stmt.c (expand_decl): Likewise.
980 * rtl.def (REG): Add new field.
981 * rtl.h (struct reg_attrs): New.
982 (rtunion_def): At rtreg.
983 (X0MEMATTR): Add checking.
984 (X0REGATTR, REG_ATTRS, REG_EXPR, REG_OFFSET): New macro.
985 (set_reg_attrs_from_mem, set_mem_attrs_from_reg, gen_rtx_REG_offset):
986 Declare.
987 * tree.h (SET_DECL_RTL): Call set_decl_rtl.
988
1d0ea52e
BW
9892003-01-24 Bob Wilson <bob.wilson@acm.org>
990
991 * config/xtensa/xtensa.c: Remove unused include of machmode.h.
992 (xtensa_emit_call, print_operand): Fix printf format strings
993 to avoid compile warnings.
994 (xtensa_function_prologue, xtensa_function_epilogue): Change type
995 of "size" argument to HOST_WIDE_INT to fix compile warnings.
996 * config/xtensa/xtensa-protos.h
997 (xtensa_function_prologue, xtensa_function_epilogue): Ditto.
998
272f51a3
JH
999Fri Jan 24 23:03:32 CET 2003 Jan Hubicka <jh@suse.cz>
1000
1001 * builtins.c (DEF_BUILTIN): Accept 10 arguments.
1002 (implicit_built_in_decls): New global array.
1003 (mathfn_built_in): New global function.
1004 (fold_trunc_transparent_mathfn): New static function
1005 (expand_builtin_strstr, expand_bultin_strchr,
1006 expand_builtin_strpbrk, expand_builtin_strcpy,
1007 expand_builtin_strncpy, expand_bultin_strcmp,
1008 expand_bultin_strncat, expand_builtin_fputs): Use
1009 implicint_built_in_decls.
1010 (fold_builtin): Fold floor/trunc/round/ceil/nearbyint.
1011 * builtins.def: Fix comments.
1012 (DEF_GCC_BUILTIN, DEF_FALLBACK_BUILTIN, DEF_EXT_FALLBACK_BUILTIN,
1013 DEF_LIB_BUILTIN, DEF_LIB_ALWAYS_BUILTIN, DEF_EXT_LIB_BUILTIN,
1014 DEF_C99_BULTIN, DEF_FRONT_END_LIB_BUILTIN,
1015 DEF_EXT_FRONT_END_LIB_BUILTIN): Pass implicit as needed.
1016 (DEF_C99_C90RES_BULTIN): New.
1017 (*f, *l builtins): Update.
1018 * c-common.c (DEF_BUILTIN): Initialize implicit array.
1019 (c_expand_builtin_printf, c_expand_builtin_fprintf): Update.
1020 * convert.c (strip_float_extensions): New global function.
1021 * tree.h (DEF_BUILTIN): Accept 10 arguments.
1022 (implicit_built_in_decls, mathfn_built_in, strip_float_extension):
1023 Declare.
1024 * java/builtins.c (define_builtin): Handle implicit.
1025 (DEF_BUILTIN): Update.
1026 * tm.texi (TARGET_C99_FUNCTIONS): Document.
1027 * defaults.h (TARGET_C99_FUNCTIONS): Default to 0.
1028 * config/linux.h (TARGET_C99_FUNCTIONS): Default to 1
1029 when using glibc2.
1030
1f37a5b2
BW
10312003-01-24 Bob Wilson <bob.wilson@acm.org>
1032
1033 * config.gcc (xtensa-*-elf*): Removed assignments to with_newlib,
1034 extra_parts, and fixincludes. Add xtensa/t-elf tmake_file.
1035 (xtensa-*-linux*): Add xtensa/t-linux tmake_file.
1036 * config/xtensa/crti.asm: New file.
1037 * config/xtensa/crtn.asm: New file.
1038 * config/xtensa/t-elf: New file.
1039 * config/xtensa/t-linux: New file.
1040 * config/xtensa/t-xtensa: Add rules for crti.o and crtn.o.
1041 Move various CFLAGS settings to new t-elf file.
1042
84f5e1b1
RH
10432003-01-24 Richard Henderson <rth@redhat.com>
1044
1045 PR optimization/4382
1046 * tree-inline.c (find_builtin_longjmp_call_1): New.
1047 (find_builtin_longjmp_call): New.
1048 (inlinable_function_p): Use it.
1049
09b2e78d
ZD
10502003-01-24 Zdenek Dvorak <rakdver@atrey.karlin.mff.cuni.cz>
1051
1052 * config/i386/i386-protos.h (function_arg_pass_by_reference): Declare.
1053 * config/i386/i386.h (FUNCTION_ARG_PASS_BY_REFERENCE): Use it.
1054 * config/i386/i386.c (function_arg_pass_by_reference): New.
1055 (ix86_va_arg): Support arguments passed by reference.
1056
3d436d2a
ZD
10572003-01-24 Zdenek Dvorak <rakdver@atrey.karlin.mff.cuni.cz>
1058
1059 * cfgloopanal.c: New file.
1060 * cfgloopmanip.c: New file.
1061 * Makefile.in (cfgloopanal.o, cfgloopmanip.o): New.
1062 (toplev.o, loop.o, doloop.o, unroll.o, cfgloop.o, predict.o,
1063 cfglayout.o): Add dependency on cfgloop.h.
1064 (cfgloop.o): Add flags.h dependency.
1065 * basic-block.h (BB_IRREDUCIBLE_LOOP, BB_SUPERBLOCK): New flags.
1066 (VLS_EXPECT_PREHEADERS, VLS_EXPECT_SIMPLE_LATCHES): Removed.
1067 (struct loop, struct loops, flow_loops_find, flow_loops_update,
1068 flow_loops_free, flow_loops_dump, flow_loop_dump,
1069 flow_loop_scan, flow_loop_tree_node_add, flow_loop_tree_node_remove,
1070 LOOP_TREE,,LOOP_PRE_HEADER, LOOP_ENTRY_EDGES, LOOP_EXIT_EDGES,
1071 LOOP_ALL, flow_loop_outside_edge_p, flow_loop_nested_p,
1072 flow_bb_inside_loop_p, get_loop_body, loop_preheader_edge,
1073 loop_latch_edge, add_bb_to_loop, remove_bb_from_loops,
1074 find_common_loop, verify_loop_structure): Declarations moved to ...
1075 * cfgloop.h: New file.
1076 * bb-reorder.c (reorder_basic_blocks): Modified.
1077 * cfglayout.c: Include cfgloop.h.
1078 (cleanup_unconditional_jumps, cfg_layout_redirect_edge,
1079 cfg_layout_duplicate_bb, cfg_layout_initialize): Update loop structure.
1080 (break_superblocks): New static function.
1081 (cfg_layout_finalize): Use it.
1082 (cfg_layout_split_block): New function.
1083 * cfglayout.h (struct reorder_block_def): Add copy and duplicated
1084 fields.
1085 (cfg_layout_initialize, cfg_layout_redirect_edge): Declaration
1086 changed.
1087 (cfg_layout_split_block): Declare.
1088 * cfgloop.c: Include cfgloop.h and flags.h.
1089 (flow_loop_dump, flow_loops_free, flow_loop_exit_edges_find,
1090 get_loop_body): Avoid signed versus unsigned comparison warnings.
1091 (make_forwarder_block, flow_loops_find, loop_preheader_edge,
1092 loop_latch_edge): Modified.
1093 (verify_loop_structure): Modified to use flags stored in loop structure;
1094 check irreducible loops.
1095 (cancel_loop, cancel_loop_tree): New functions.
1096 (estimate_probability): Use loop analysis code for predictions.
1097 (estimate_loops_at_level): Avoid signed versus unsigned comparison
1098 warnings.
1099 * doloop.c: Include cfgloop.h.
1100 * loop.c: Include cfgloop.h.
1101 * predict.c: Include cfgloop.h.
1102 * toplev.c: Include cfgloop.h.
1103 * unroll.c: Include cfgloop.h.
1104 * tracer.c (tracer): Modified.
1105
a38b3eea
KH
11062003-01-24 Kazu Hirata <kazu@cs.umass.edu>
1107
1108 * config/h8300/h8300.c (get_shift_alg): Fix a typo.
1109
fd3cd001
UW
11102003-01-24 Ulrich Weigand <uweigand@de.ibm.com>
1111
1112 * configure.in (HAVE_AS_TLS): Add s390-*-* and s390x-*-* cases.
1113 * configure: Regenerate.
1114
1115 * config/s390/s390-protos.h (tls_symbolic_operand): Add prototype.
1116 (tls_symbolic_reference_mentioned_p): Add prototype.
1117 (s390_tls_get_offset): Add prototype.
1118 (emit_pic_move): Remove prototype, replace by ...
1119 (emit_symbolic_move): .. this new prototype.
1120
1121 * config/s390/s390.c (TARGET_HAVE_TLS): Conditionally define.
1122 (tls_model_chars): New global variable.
1123 (s390_encode_section_info): Encode TLS model.
1124 Use targetm.binds_local_p to check for local symbols.
1125 (s390_strip_name_encoding): New function.
1126 (TARGET_STRIP_NAME_ENCODING): Define.
1127
1128 (get_thread_pointer): New function.
21ff35fb 1129 (legitimize_tls_address): New function.
fd3cd001
UW
1130 (legitimize_address): Call it.
1131 (emit_pic_move): Remove, replace by ...
1132 (emit_symbolic_move): ... this new function.
1133
1134 (larl_operand): Handle TLS operands.
1135 (legitimate_constant_p): Likewise.
1136 (s390_decompose_address): Likewise.
1137 (s390_cannot_force_const_mem): New function.
1138 (TARGET_CANNOT_FORCE_CONST_MEM): Define.
1139
1140 (s390_output_symbolic_const): Handle TLS unspecs.
1141 (print_operand): New code 'J'.
1142 (machine_function): Add struct member 'some_ld_name'.
1143 (get_some_local_dynamic_name, get_some_local_dynamic_name_1): New.
1144
1145 (enum s390_builtin): New type.
1146 (code_for_builtin_64, code_for_builtin_31): New global variables.
1147 (s390_init_builtins, s390_expand_builtin): New functions.
1148 (TARGET_INIT_BUILTINS, TARGET_EXPAND_BUILTIN): Define.
1149
1150 * config/s390/s390.h (TLS_SYMBOLIC_CONST): New macro.
1151 (ASM_OUTPUT_LABELREF): Define.
1152 (ASM_OUTPUT_SPECIAL_POOL_ENTRY): Handle TLS constants.
1153
1154 * config/s390/s390.md: Define TLS UNSPEC constants.
1155 ("movdi", "movsi"): Handle TLS operands.
1156 ("get_tp_64", "get_tp_31", "set_tp_64", "set_tp_31"): New insns.
1157 ("*tls_load_64", "*tls_load_31"): New insns.
1158 ("call_value_tls", "call_value_tls_exp"): New expanders.
21ff35fb 1159 ("brasl_tls", "bras_tls", "basr_tls_64", "basr_tls_31",
fd3cd001
UW
1160 "bas_tls_64", "bas_tls_31"): New insns.
1161
01f4962d
NS
11622003-01-24 Nathan Sidwell <nathan@codesourcery.com>
1163
1164 * config/rs6000/rs6000.c (rs6000_parse_abi_options): Make sure
1165 spe ABI is configured, if requested.
1166
70b91854
VR
11672003-01-24 Volker Reichelt <reichelt@igpm.rwth-aachen.de>
1168
1169 * doc/passes.texi: Fix typo.
1170
b8089d8d
AS
11712003-01-24 Andreas Schwab <schwab@suse.de>
1172
1173 * stor-layout.c (excess_unit_span): Only define if used.
1174
38df970e
JQ
11752003-01-24 Jerry Quinn <jlquinn@optonline.net>
1176
1177 * gcc/doc/invoke.texi (Optimization Options): List -O levels
1178 for each optimization flag.
1179
dff23a65
KH
11802003-01-24 Kazu Hirata <kazu@cs.umass.edu>
1181
1182 * config/h8300/h8300.md (*andsi3_ashift_n_lower): New.
1183
05739753
VR
11842003-01-24 Volker Reichelt <reichelt@igpm.rwth-aachen.de>
1185
1186 * doc/bugreport.texi: Use @command instead of @code for commands.
1187 * doc/collect2.texi: Likewise.
1188 * doc/headerdirs.texi: Likewise.
1189 * doc/invoke.texi: Likewise.
1190 * doc/standards.texi: Likewise.
1191 * doc/tm.texi: Likewise.
1192 * doc/trouble.texi: Likewise.
1193
06bea5aa
NC
11942003-01-24 Nick Clifton <nickc@redhat.com>
1195
1196 * config/arm/arm.c (use_return_insn): Do not use a single return
1197 instruction for interrupt handelrs which have to create a stack
1198 frame.
1199 (arm_expand_prologue): Do not pre-bias the return address of
1200 interrupt handlers which create a stack frame.
1201
12022003-01-24 Nick Clifton <nickc@redhat.com>
1203
1204 * Add sh2e support:
1205
1206 2002-08-12 Alexandre Oliva <aoliva@redhat.com>
1207
1208 * config/sh/sh.c (output_branch) [TARGET_SH2E]: Handle
1209 med_cbranches. Fix logic in short_cbranches.
1210
1211 2002-04-03 Alexandre Oliva <aoliva@redhat.com>
1212
1213 * config/sh/sh.md (delay for cbranch): Don't annul delay
1214 slots on SH2e.
1215 * config/sh/sh.c (sh_insn_length_adjustment): Add 2 for
1216 cbranch with unfilled delay slot on SH2e.
1217 (output_branch): Fill with a nop the delay slot of a
1218 branch that required a delay slot but didn't get one.
1219
1220 2002-04-02 Alexandre Oliva <aoliva@redhat.com>
1221
1222 * doc/invoke.texi (SH options): Document -m2e.
1223 * config/sh/crt1.asm: Add __SH2E__ Next to __SH3E__.
1224 * config/sh/lib1funcs.asm: Likewise.
1225 * config/sh/sh.c: Replace all uses of TARGET_SH3E with SH2E.
1226 * config/sh/sh.h (CPP_SPEC): Define __SH2E__ for -m2e, and
1227 not __sh1__.
1228 (CONDITIONAL_REGISTER_USAGE): Don't disable FP regs from
1229 SH2E up.
1230 (SH3E_BIT): Renamed to...
1231 (SH_E_BIT): ... this. Replace all uses.
1232 (TARGET_SH2E): Define from SH_E_BIT and TARGET_SH2.
1233 Replace all uses of TARGET_SH3E with TARGET_SH2E.
1234 (TARGET_SWITCHES): Added 2e.
1235 (OVERRIDE_OPTIONS): Set sh_cpu for SH2E.
1236 (processor_type): Added PROCESSOR_SH2E.
1237 * config/sh/sh.md: Replace all uses of TARGET_SH3E with
1238 TARGET_SH2E, except in sqrtsf2_i.
1239 (attribute cpu): Added sh2e.
1240 * config/sh/t-sh (MULTILIB_OPTIONS): Replace m3e with m2e.
1241 (MULTILIB_MATCHES): Use m2e multilib for m3e.
1242 * config.gcc: Add sh2e target support.
1243
65ca2d60
PE
12442003-01-24 Phil Edwards <pme@gcc.gnu.org>
1245
1246 Rename -W to -Wextra.
1247 * c-decl.c: Update comments.
1248 * c-typeck.c: Likewise.
1249 * flags.h: Likewise.
1250 * function.c: Likewise.
1251 * stmt.c: Likewise.
1252 * toplev.c: Update comments.
1253 (W_options): Add 'extra'.
1254 (display_help): Remove '-W'.
1255 (decode_W_option): Special warn_uninitialized treatment in the case
1256 of -Wextra.
1257 * doc/invoke.texi: Update with new entries.
1258
3de9c088
RH
12592003-01-23 Richard Henderson <rth@redhat.com>
1260
8324663f
RH
1261 * ifcvt.c (noce_process_if_block): Re-add check vs X being changed
1262 in no-else-block case. Add commentary.
3de9c088 1263
49691411
KG
12642003-01-23 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
1265
b4862477
KG
1266 * configure.in: Revert last change.
1267
12682003-01-23 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
1269
1270 * configure.in: Don't include ansidecl.h in tconfig.h.
49691411
KG
1271 * gcov-io.h (PARAMS, ATTRIBUTE_UNUSED: Define if IN_LIBGCC2.
1272 * unwind-dw2-fde.h (last_fde): Use __attribute__, not
1273 ATTRIBUTE_UNUSED.
1274
1275 * configure: Regenerate.
1276
c4db7ecb
FS
12772003-01-23 Franz Sirl <Franz.Sirl-kernel@lauterbach.com>
1278
1279 PR java/6748
1280 * config/rs6000/linux.h (MD_FALLBACK_FRAME_STATE_FOR): Don't destroy
1281 regs->nip. Fix rt_sigreturn frame layout. Add support for newer
1282 kernels.
1283
fc69c47c
KG
12842003-01-23 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
1285
1286 * cpplex.c (cpp_interpret_charconst): Squelch warning with cast.
1287
adbe6dfd
UW
12882003-01-23 Ulrich Weigand <uweigand@de.ibm.com>
1289
1290 * genattrtab.c (write_attr_get): Mark 'insn' paramter
1291 as ATTRIBUTE_UNUSED.
1292
76a318e9
RE
12932003-01-23 Richard Earnshaw <rearnsha@arm.com>
1294
1295 * arm.c (thumb_base_register_rtx_p): New function.
1296 (thumb_index_register_rtx_p): New function.
1297 (thumb_legitimate_address_p): New function.
1298 (thumb_legitimate_offset_p): New function.
1299 * arm.h (REG_STRICT_P): Define according to setting of REG_OK_STRICT.
8891b787 1300 (ARM_GO_IF_LEGITIMATE_ADDRESS): Use REG_STRICT_P to avoid duplicate
76a318e9
RE
1301 definitions.
1302 (THUMB_GO_IF_LEGITIMATE_ADDRESS): Use thumb_legitimate_address_p.
1303 (THUMB_LEGITIMATE_OFFSET): Delte.
1304 (THUMB_LEGITIMIZE_RELOAD_ADDRESS): Use thumb_legitimate_offset.
1305 * arm-protos.h (thumb_legitimate_address_p): Add prototype.
1306 (thumb_legitimate_offset_p): Likewise.
1307
9a600d0c
AS
13082003-01-23 Andreas Schwab <schwab@suse.de>
1309
1310 * unwind.h (_Unwind_GetTextRelBase): Mark parameter as unused.
1311
2d110c0a
KG
13122003-01-23 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
1313
1314 * fixinc/Makefile.in (FL_LIST): Revert last change.
1315
2d1d9215
VR
13162003-01-23 Volker Reichelt <reichelt@igpm.rwth-aachen.de>
1317
1318 PR other/7341
1319 * invoke.texi (ftest-coverage): Fix broken cross-reference.
1320 Change @code to @command for gcov command.
1321
1322 * gcc.texi: Adjust title of gcov section.
1323 Adjust copyright.
1324 * gcov.texi: Likewise.
1325
34ee7f82
RS
13262003-01-22 Roger Sayle <roger@eyesopen.com>
1327
1328 PR optimization/8423
1329 * cse.c (fold_rtx): Only eliminate a CONSTANT_P_RTX to 1 when
1330 its argument is constant, or 0 if !flag_gcse.
1331 * simplify-rtx.c (simplify_rtx): Convert CONSTANT_P_RTX to 1
1332 if it's argument is constant.
1333 * gcse.c (want_to_gcse_p): Ignore CONSTANT_P_RTX nodes.
1334 (hash_scan_set): Don't record CONSTANT_P_RTX expressions.
1335 (do_local_cprop): Don't propagate CONSTANT_P_RTX constants.
1336 * builtins.c (purge_builtin_constant_p): New function to force
1337 instantiation of any remaining CONSTANT_P_RTX nodes.
1338 * rtl.h (purge_builtin_constant_p): Prototype here.
1339 * toplev.c (rest_of_compilation): Invoke purge_builtin_constant_p
1340 pass after GCSE and before loop.
1341 (flag_gcse): No longer static.
1342 * flags.h (flag_gcse): Prototype here.
1343
bab0b43b
UW
13442003-01-22 Ulrich Weigand <uweigand@de.ibm.com>
1345
1346 * config/s390/s390.h (HARD_REGNO_MODE_OK): Fix warning regression
1347 introduced by last change.
1348
7e657a61
AS
13492003-01-22 Andreas Schwab <schwab@suse.de>
1350
1351 * ra-rewrite.c (rewrite_program2): Initialize bb to avoid warning.
1352
75a3503b
KH
13532003-01-22 Kazu Hirata <kazu@cs.umass.edu>
1354
1355 * config/h8300/h8300.c (h8300_shift_needs_scratch_p): Don't
1356 request a scratch reg on H8S when the shift count is 8.
1357
4888ec5d
UW
13582003-01-22 Ulrich Weigand <uweigand@de.ibm.com>
1359
1360 * config/s390/s390-protos.h (preferred_la_operand_p):
1361 Remove second parameter.
1362 * config/s390/s390.c (preferred_la_operand_p): Likewise.
1363 * config/s390/s390.h (FRAME_REGNO_P, FRAME_REG_P): New macros.
1364 (HARD_REGNO_MODE_OK): Use FRAME_REGNO_P.
1365 * config/s390/s390.md ("*la_cc_64", "*la_cc_31", splitters): Remove.
1366 Add peepholes to transform ADD to LOAD ADDRESS.
1367
6b990f6b
RE
13682003-01-22 Richard Earnshaw <rearnsha@arm.com>
1369
1370 * arm.c (arm_address_register_rtx_p): New function.
1371 (arm_legitimate_address_p): New function.
1372 (arm_legitimate_index_p): New function.
1373 (legitimize_pic_address): Use arm_legitimate_index_p.
1374 * arm-protos.h (arm_legtimate_address_p): Add prototype.
1375 * arm.h (ARM_GO_IF_LEGITIMATE_INDEX): Delete.
1376 (ARM_GO_IF_LEGITIMATE_ADDRESS): Call arm_legitimate_address_p.
1377
f0bf1270
HP
13782003-01-22 Hartmut Penner <hpenner@de.ibm.com>
1379
1380 * config/s390/s390.md (floatdfdi2): Insn has type 'itof'.
1381 * config/s390/2064.md (define_bypass): Correct 'Load' and
1382 'Load-address' bypass values.
21ff35fb 1383
fcb6a0f5
AS
13842003-01-22 Andreas Schwab <schwab@suse.de>
1385
1386 * config/ia64/t-ia64 (insn-attrtab.o-warn): Define as -Wno-error.
1387
c24b8026
ZW
13882003-01-21 Zack Weinberg <zack@codesourcery.com>
1389
1390 * genautomata.c (output_internal_insn_latency_func,
1391 output_print_reservation_func): Short circuit when there is no
1392 automaton to generate code for.
1393
38afe605
KG
13942003-01-21 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
1395
1396 * Makefile.in (ssa-ccp.o): Depend on coretypes.h $(TM_H).
1397 (df.o): Delete duplicate dependency on coretypes.h $(TM_H).
1398
d24652ee
GK
13992003-01-21 Geoffrey Keating <geoffk@apple.com>
1400
1401 * config/rs6000/rs6000.md: Remove warning.
1402 (builtin_setjmp_receiver): Likewise.
1403 * config/darwin.c (update_stubs): Slightly improve terrible hack
1404 with identifiers. Add comment pointing out problems with it.
1405 (update_non_lazy_ptrs): Likewise.
1406
1c99d804
RH
14072003-01-21 Richard Henderson <rth@redhat.com>
1408
1409 * dwarf2out.c (lookup_filename): Fix printf format warning.
1410 * system.h (fread_unlocked, fwrite_unlocked): Undef.
1411
1412 * fixinc/Makefile.in (FL_LIST): Add $($@-warn) hook.
1413 (fixincl.o-warn, gnu-regex.o-warn): New.
1414 * fixinc/fixfixes.c (FIX_PROC_HEAD): Mark parameters unused.
1415 * fixinc/fixtests.c (TEST_FOR_FIX_PROC_HEAD): Likewise.
1416 * fixinc/fixincl.c (process): Fix printf format warning.
1417
f0b886ab
UW
14182003-01-21 Ulrich Weigand <uweigand@de.ibm.com>
1419
1420 * dwarf2out (output_file_names): Don't crash if called
1421 with empty file_table.
1422
490c57bb
ZW
14232003-01-21 Zack Weinberg <zack@codesourcery.com>
1424
1425 * genautomata.c (output_internal_insn_latency_func): Add
1426 missing break statement to generated code.
1427
100e3acb
RS
14282003-01-21 Roger Sayle <roger@eyesopen.com>
1429
1430 * stmt.c (same_case_target_p): New function to determine whether
1431 two case labels branch to the same target. Split out from...
1432 (group_case_nodes): ... here. Use same_case_target_p instead.
1433 (strip_default_case_nodes): Remove explicit case nodes
1434 that branch to the default destination.
1435 (expand_end_case_type): Call strip_default_case_nodes after
1436 group_case_nodes, to simplify the case-list before we count it.
1437 Only generate table_label RTX when actually needed. Try to share
1438 thiscase->exit_label and thiscase->data.case_stmt.default_label
1439 when a switch has no explicit default case. Simplify test for
1440 constant index.
1441
e8e8c1e5
KH
14422003-01-21 Kazu Hirata <kazu@cs.umass.edu>
1443
1444 * config/h8300/h8300.md (*negsf2_h8300): Use \\t instead of
1445 \t.
1446 (*negsf2_h8300hs): Likewise.
1447 (*addsi3_lshiftrt_16_zexthi): Likewise.
1448 (*iorhi3_lshiftrt_8): Likewise.
1449
044b4de3
UW
14502003-01-21 Ulrich Weigand <uweigand@de.ibm.com>
1451
1452 * dwarf2out.c (fde_table_in_use): Mark GTY.
1453 (dwarf2out_cfi_label_num): New variable, marked GTY.
1454 (dwarf2out_cfi_label): Use it instead of static label_num.
1455 * emit-rtl.c (label_num): Mark GTY.
1456
cfedf91b
KH
14572003-01-21 Kazu Hirata <kazu@cs.umass.edu>
1458
1459 * config/h8300/h8300.c (output_plussi): Support H8/300.
1460 (compute_plussi_length): Likewise.
1461 (compute_plussi_cc): Likewise.
1462 * config/h8300/h8300.md (addsi_h8300): Use output_plussi to
1463 output assembly instructions.
1464
dd859b8a
KG
14652003-01-21 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
1466
1f5b3282
KG
1467 * calls.c (fix_unsafe_tree): Prototype.
1468
dd859b8a
KG
1469 * Makefile.in (GCC_WARN_CFLAGS): Add $(WERROR) $($@-warn)
1470 (gtype-desc.o-warn, c-decl.o-warn, varasm.o-warn, gcc.o-warn,
1471 insn-conditions.o-warn, out_object_file, gengtype-yacc.o-warn,
1472 c-parse.o-warn): Add -Wno-error.
1473 (STAGE2_FLAGS_TO_PASS): Add WERROR="@WERROR@".
1474
1475 * configure.in (--enable-werror): Add new flag.
1476 * doc/install.texi (--enable-werror): Document.
1477 * configure: Regenerate.
1478
1479 * objc/Make-lang.in (objc/objc-parse.o-warn): Add -Wno-error.
1480
4f9365e2
AS
14812003-01-21 Andreas Schwab <schwab@suse.de>
1482
1483 * genautomata.c (output_internal_insn_latency_func): Fix missing
1484 close paren in output.
1485
a543eb5e
ZW
14862003-01-21 Zack Weinberg <zack@codesourcery.com>
1487
1488 * genautomata.c: Space savings in generated code:
1489 (output_dfa_insn_code_func): Split out the table-enlargement
1490 path to an out-of-line static function, dfa_insn_code_enlarge.
1491 (output_internal_insn_latency_func): Use a lookup table for the
1492 default latencies.
1493 (output_print_reservation_func): Use a lookup table for the
1494 strings.
1495
292e35a3
CE
14962003-01-21 Christian Ehrhardt <ehrhardt@mathematik.uni-ulm.de>
1497
1498 PR opt/7507
1499 * calls.c (fix_unsafe_tree): Split out from ...
1500 (expand_call): ... here. Use it on the function address too.
1501
d8d0f5af
RH
15022003-01-20 Richard Henderson <rth@redhat.com>
1503
1504 * expr.h (default_must_pass_in_stack): Move decl outside ifdef.
1505
5b50aa9d
RH
15062003-01-20 Richard Henderson <rth@redhat.com>
1507
515e1c9f 1508 PR opt/7154
5b50aa9d
RH
1509 * stmt.c (expand_asm_operands): Validize memory operands.
1510
7a174a15
RH
15112003-01-20 Richard Henderson <rth@redhat.com>
1512
1513 PR opt/8848
1514 * ifcvt.c (noce_process_if_block): Correct arguments to
1515 modified_between_p for no-else-block case.
1516
9ac7ebba
KH
15172003-01-20 Kazu Hirata <kazu@cs.umass.edu>
1518
1519 * config/h8300/h8300.c (const_costs): Remove a warning.
1520 (output_plussi): Likewise.
1521 (compute_plussi_length): Likewise.
1522 (compute_plussi_cc): Likewise.
1523
309c52b5
KH
15242003-01-20 Kazu Hirata <kazu@cs.umass.edu>
1525
1526 * config/h8300/h8300.md (addsi_h8300): Remove the last
1527 alternative.
1528
b30686ec
KH
15292003-01-20 Kazu Hirata <kazu@cs.umass.edu>
1530
1531 * config/h8300/h8300.c (get_shift_alg): Remove redundant code.
1532
87608693
KG
15332003-01-20 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
1534
1535 * system.h (__NO_STRING_INLINES): Define.
1536
475c8250
JDA
15372003-01-20 John David Anglin <dave.anglin@nrc-cnrc.gc.ca>
1538
1539 * ifcvt.c (noce_emit_store_flag): Don't emit store flag if mode of x
1540 is not a scalar int mode.
1541
dbaff908
RS
15422003-01-20 Roger Sayle <roger@eyesopen.com>
1543
1544 * cse.c (cse_insn): Avoid RTL sharing when updating the RETVAL
1545 insn's notes following a substitution inside a libcall.
1546
da8a6064
ZW
15472003-01-20 Zack Weinberg <zack@codesourcery.com>
1548
1549 * configure.in: Check for system-provided 'uchar' type.
a12b5bd9 1550 * configure, config.in: Regenerate.
da8a6064
ZW
1551 * cpphash.h: Only typedef 'uchar' if the system doesn't.
1552
a4b1b92a
RH
15532003-01-20 Richard Henderson <rth@redhat.com>
1554
1555 * expr.h (MUST_PASS_IN_STACK): Move implementation...
1556 * calls.c (default_must_pass_in_stack): ... here.
1557
d530b07f
VM
15582003-01-20 Vladimir Makarov <vmakarov@redhat.com>
1559
da8a6064
ZW
1560 * genattrtab.h (INSN_ALTS_FUNC_NAME): Move it from genautomata.c.
1561
d530b07f
VM
1562 * genautomata.c (INSN_ALTS_FUNC_NAME): Move it into genattrtab.h.
1563
1564 * genattr.c (main): Output default definition of AUTOMATON_ALTS.
1565 Wrap up definition of `insn_alts'.
1566
1567 * genattrtab.c (main): Wrap up `insn_alts'.
1568
351df804
KG
15692003-01-20 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
1570
1571 * collect2.c (ldgetname): Check HAVE_DECL_LDGETNAME before
1572 prototyping.
1573 * configure.in: Check for <ldfcn.h> and ldgetname() prototype.
da8a6064 1574
351df804
KG
1575 * config.in, configure: Regenerate.
1576
e3289412
NC
15772003-01-20 Nick Clifton <nickc@redhat.com>
1578
1579 * config/arm/arm.md (sibcall_epilogue): Add an
1580 UNSPEC_PROLOGUE_USE to prevent the link register from being
1581 considered dead.
1582
5794139a
JH
1583Mon Jan 20 14:36:23 CET 2003 Jan Hubicka <jh@suse.cz>
1584
1585 * i386.md (SSE cmov splitter): Handle memory operand in operand 5.
1586
0a18ddf9
AS
15872003-01-20 Andreas Schwab <schwab@suse.de>
1588
1589 * system.h: Don't declare strsignal if the decl test hasn't been
1590 run yet.
1591
d99c740f
KH
15922003-01-20 Kazu Hirata <kazu@cs.umass.edu>
1593
1594 * config/h8300/h8300.c (notice_update_cc): Don't assume that
1595 recog_data.operands[0] is always associated with cc0.
1596
825c5408
DE
15972003-01-19 David Edelsohn <edelsohn@gnu.org>
1598
1599 * collect2.c (ldgetname): Expand declaration to prototype.
1600 * read-rtl.c (atoll): Add prototype.
da3e0142 1601 * system.h (strsignal): Also declare if no declaration found.
825c5408 1602
3bd6d4c4
AO
16032003-01-19 Alexandre Oliva <aoliva@redhat.com>
1604
1605 * config.gcc (mips64*-*-linux*): Added.
1606 * config/mips/linux64.h, config/mips/t-linux64: New file.
1607 * config/mips/iris6.h (MIPS_TFMODE_FORMAT): Define.
1608 * config/mips/mips.c (override_options): Use it.
1609 * config/mips/mips.h (TARGET_SWITCHES): Added...
1610 (SUBTARGET_TARGET_SWITCHES): New, empty by default.
1611 * Makefile.in (SPECS): New.
1612 (STAGESTUFF, specs, mostlyclean, install-common): Use it.
1613 * gcc.c (process_command): Move self-spec processing past spec
1614 file loading.
1615 * doc/tm.texi (DRIVER_SELF_SPECS): Document the change.
1616 * doc/fragments.texi (MULTILIB_EXTRA_OPTS): Document need for
1617 CRTSTUFF_T_CFLAGS.
1618 (SPECS): Document.
1619 * doc/invoke.texi (-mabi-fake-default): Document.
1620
e9f13564
SC
16212003-01-19 Stephane Carrez <stcarrez@nerim.fr>
1622
1623 * config/m68hc11/m68hc11.c (stack_push_word, stack_pop_word,
1624 z_reg, z_reg_qi): Declare static and GTY().
1625 (da_reg): Remove.
1626 (create_regs_rtx): Don't create da_reg.
1627 ("gt-m68hc11.h"): Include for GTY roots.
1628 * config/m68hc11/m68hc11.h (ix_reg, iy_reg, d_reg): Declare extern
1629 and GTY() here.
1630 (m68hc11_compare_op0, m68hc11_compare_op1): Likewise.
1631 (m68hc11_soft_tmp_reg): Likewise.
1632 * config/m68hc11/m68hc11-protos.h: Remove above declarations.
1633
32dd366d
KH
16342003-01-18 Kazu Hirata <kazu@cs.umass.edu>
1635
1636 * basic-block.h: Fix comment formatting.
1637 * calls.c: Likewise.
1638 * combine.c: Likewise.
1639 * convert.c: Likewise.
1640 * gcov.c: Likewise.
1641 * haifa-sched.c: Likewise.
1642 * libgcc2.c: Likewise.
1643 * loop.c: Likewise.
1644 * profile.c: Likewise.
1645 * system.h: Likewise.
1646
bc3cb712
RS
16472003-01-18 Roger Sayle <roger@eyesopen.com>
1648
1649 * config/pa/pa.md (muldi3): Avoid invalid sharing of SUBREG RTXs.
1650
25e42e9d
KG
16512003-01-17 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
1652
1653 * ra-build.c (undef_to_size_word): Avoid `switch' warning.
1654
6f9c81f5
DJ
16552003-01-17 Dale Johannesen <dalej@apple.com>
1656
da8a6064 1657 * config/rs6000/rs6000.md (*floatsidf2_internal): Add earlyclobbers.
6f9c81f5
DJ
1658 (*floatunssidf2_internal): Ditto.
1659
95bd1dd7
KH
16602003-01-17 Kazu Hirata <kazu@cs.umass.edu>
1661
1662 * alias.c: Fix comment typos.
1663 * basic-block.h: Likewise.
1664 * c-common.c: Likewise.
1665 * c-common.h: Likewise.
1666 * c-decl.c: Likewise.
1667 * c-opts.c: Likewise.
1668 * c-pragma.c: Likewise.
1669 * c-pretty-print.h: Likewise.
1670 * cfg.c: Likewise.
1671 * cfganal.c: Likewise.
1672 * cfgbuild.c: Likewise.
1673 * cfgcleanup.c: Likewise.
1674 * cfglayout.c: Likewise.
1675 * cfgrtl.c: Likewise.
1676 * convert.c: Likewise.
1677 * cpphash.h: Likewise.
1678 * cpplex.c: Likewise.
1679 * cpplib.h: Likewise.
1680 * df.h: Likewise.
1681 * diagnostic.c: Likewise.
1682 * diagnostic.h: Likewise.
1683 * dwarf2.h: Likewise.
1684
d5840e09
SS
16852003-01-17 Stan Shebs <shebs@apple.com>
1686
1687 * config/darwin-protos.h: Forward-declare struct cpp_reader.
1688
e607534b
DR
16892003-01-17 Douglas B Rupp <rupp@gnat.com>
1690
1691 * config/alpha/alpha.c (alpha_need_linkage): Fix obvious
1692 mistake in last checkin.
1693
fbe5a4a6
KH
16942003-01-17 Kazu Hirata <kazu@cs.umass.edu>
1695
1696 * et-forest.c: Fix comment typos.
1697 * et-forest.h: Likewise.
1698 * except.c: Likewise.
1699 * expr.c: Likewise.
1700 * flags.h: Likewise.
1701 * flow.c: Likewise.
1702 * gcc.c: Likewise.
1703 * gcse.c: Likewise.
1704 * genattrtab.c: Likewise.
1705 * genautomata.c: Likewise.
1706 * gengtype.c: Likewise.
1707 * genrecog.c: Likewise.
1708 * global.c: Likewise.
1709 * gthr-rtems.h: Likewise.
1710
095f9093
KG
17112003-01-17 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
1712
1713 * i386.c (x86_function_profiler): Fix format specifier.
1714
084087e1
RH
17152003-01-17 Richard Henderson <rth@redhat.com>
1716
1717 * gengtype.c (walk_type): Allow paramN_is.
1718
4a13592e
NC
17192003-01-17 Nick Clifton <nickc@redhat.com>
1720
1721 * config/i960/t-960bare (i960-c.o): Add missing newline escape.
1722
01193617
RH
17232003-01-16 Richard Henderson <rth@redhat.com>
1724
1725 * config/alpha/linux-elf.h (LIB_SPEC): Adjust inter-option spacing.
1726
f030826a
RH
17272003-01-16 Richard Henderson <rth@redhat.com>
1728
1729 * config/alpha/alpha.c (alpha_sr_alias_set): Mark GTY.
1730 (alpha_next_sequence_number): Likewise.
1731 (alpha_this_literal_sequence_number): Likewise.
1732 (alpha_this_gpdisp_sequence_number): Likewise.
1733 (struct alpha_funcs, alpha_funcs_num): Likewise.
1734 (struct alpha_links): Fix branch merge error.
1735 (alpha_need_linkage, alpha_use_linkage): Use GC for alpha_funcs.
1736
e1551d47
AO
17372003-01-17 Alexandre Oliva <aoliva@redhat.com>
1738
1739 * config/mips/mips.h: Don't use #elif. Reported by Kaveh
1740 R. Ghazi.
1741
3d042e77
KH
17422003-01-16 Kazu Hirata <kazu@cs.umass.edu>
1743
1744 * ifcvt.c: Fix comment typos.
1745 * lcm.c: Likewise.
1746 * libgcc2.c: Likewise.
1747 * local-alloc.c: Likewise.
1748 * loop.c: Likewise.
1749 * predict.c: Likewise.
1750 * ra-build.c: Likewise.
1751 * ra.c: Likewise.
1752 * ra-colorize.c: Likewise.
1753 * ra.h: Likewise.
1754 * ra-rewrite.c: Likewise.
1755 * regmove.c: Likewise.
1756 * reload.h: Likewise.
1757 * rtlanal.c: Likewise.
1758 * toplev.c: Likewise.
1759 * tree.h: Likewise.
1760 * unwind-dw2-fde-glibc.c: Likewise.
1761 * vmsdbgout.c: Likewise.
1762
c4274b22
RH
17632003-01-16 Richard Henderson <rth@redhat.com>
1764
1765 * dwarf2out.c (struct file_table): Remove.
1766 (FILE_TABLE_INCREMENT): Remove.
1767 (file_table): Make a varray; mark for GC. Update all users.
1768 (file_table_last_lookup_index): Extract from struct file_table.
1769 (output_file_names): Fix unsigned compare warnings.
1770 (add_name_attribute): Remove inline marker.
1771 (add_comp_dir_attribute): Split out from gen_compile_unit_die.
1772 (lookup_filename): Don't manage size of file_table.
1773 (init_file_table): Allocate file_table with GC.
1774 (dwarf2out_init): Don't record main_input_filename here.
1775 (dwarf2out_finish): Do it here instead.
1776
19162d0e
BK
17772003-01-16 Bruce Korb <bkorb@gnu.org>
1778
1779 * gcc/fixinc/inclhack.def(limits_ifndef): QNX needs a bypass, too.
1780
f1e2239f
KK
17812003-01-16 Kaz Kojima <kkojima@gcc.gnu.org>
1782
da8a6064
ZW
1783 * config/sh/sh.c (sh_initialize_trampoline): Emit rotrdi3_mextr
1784 instead of rotldi3_mextr.
f1e2239f 1785
cda1f765
VM
17862003-01-16 Vladimir Makarov <vmakarov@redhat.com>
1787
1788 * haifa-sched.c (move_insn): Restore moving all schedule group.
1789 (set_priorities): Restore taking SCHED_GROUP_P into account.
1790
1791 * sched-deps.c (add_dependence): Restore processing the last group
1792 insn.
1793 (remove_dependence, group_leader): Restore the functions.
1794 (set_sched_group_p): Restore adding dependencies from previous insn
1795 in the group.
1796 (compute_forward_dependences): Restore usage of group_leader.
1797
1798 * sched-ebb.c (init_ready_list): Restore taking SCHED_GROUP_P into
1799 account.
1800
1801 * sched-rgn.c (init_ready_list): Restore taking SCHED_GROUP_P into
1802 account.
1803 (can_schedule_ready_p): Ditto.
1804 (add_branch_dependences): Restore skipping over the group insns.
da8a6064 1805
200097cc
SC
18062003-01-16 Stephane Carrez <stcarrez@nerim.fr>
1807
1808 * config/m68hc11/m68hc11.c (m68hc11_check_z_replacement): Fix handling
1809 68HC12 pre/post inc/dec side effects.
1810
f411c739
SC
18112003-01-16 Stephane Carrez <stcarrez@nerim.fr>
1812
1813 * config/m68hc11/m68hc11.h (MASK_M6812): Define.
1814
08c43ea7
R
1815Thu Jan 16 21:50:25 2003 J"orn Rennecke <amylaar@onetel.net.uk>
1816
1817 * sh.md (mshflo_w_x): Fix description of operation.
1818
07488f32
ZW
18192003-01-16 Zack Weinberg <zack@codesourcery.com>
1820
1821 * config/rs6000/rs6000.h: Mention Altivec registers in
1822 commentary. Fix typo.
1823
27dc0551
DE
18242003-01-16 David Edelsohn <edelsohn@gnu.org>
1825
1826 * config/rs6000/rs6000.md (movti_string): Remove clobber.
1827 * config/rs6000/rs6000.c (rs6000_emit_move, TImode): Explicitly
1828 generate PARALLEL with clobber for TARGET_POWER.
1829
0334ef47
KG
18302003-01-16 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
1831
1832 * ra-colorize.c (colorize_one_web): Initialize variable.
1833 * regmove.c (fixup_match_1): Likewise.
1834 * reload1.c (reload_as_needed): Likewise.
1835 * sdbout.c (SET_KNOWN_TYPE_TAG): Add cast.
1836
16f2b86a
ZD
18372003-01-16 Zdenek Dvorak <rakdver@atrey.karlin.mff.cuni.cz>
1838
1839 * cfgloop.c (flow_loops_find): Fix handling of abnormal edges.
1840
fc555370
KG
18412003-01-16 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
1842
93d8c755
KG
1843 * dbxout.c (lastfile, cwd): Fix `unused' warning.
1844 * dwarf2out.c (fde_table_in_use, current_funcdef_fde,
1845 dw_cfi_oprnd1_desc, dw_cfi_oprnd2_desc, next_die_offset,
1846 is_main_source, file_table, decl_die_table_in_use,
1847 abbrev_die_table_in_use, line_info_table_in_use,
1848 separate_line_info_table_in_use, pubname_table_in_use,
1849 arange_table_in_use, ranges_table_in_use,
1850 current_function_has_inlines): Likewise.
1851 * flow.c (life_analysis): Likewise.
1852 * genemit.c (gen_insn): Likewise.
1853 * protoize.c (cplus_suffix): Likewise.
1854
0c2ca901
KG
1855 * arm.c (ROUND_UP_WORD): Renamed from ROUND_UP.
1856 * arm.h (ROUND_UP_WORD): Likewise.
1857
fc555370
KG
1858 * arm.h (CONDITIONAL_REGISTER_USAGE): Avoid signed/unsigned
1859 warning.
1860 * emit-rtl.c (gen_rtx_REG, set_mem_attributes_minus_bitpos,
1861 init_emit_once): Likewise.
1862 * flow.c (mark_regs_live_at_end, calculate_global_regs_live):
1863 Likewise.
1864 * function.c (assign_stack_temp_for_type): Likewise.
1865 * loop.c (loop_invariant_p): Likewise.
1866 * recog.c (push_operand): Likewise.
1867 * regclass.c (init_reg_sets_1): Likewise.
1868 * reload.c (update_auto_inc_notes): Likewise.
1869 * reload1.c (reload_as_needed, emit_input_reload_insns): Likewise.
1870 * stmt.c (expand_asm_operands): Likewise.
1871 * stor-layout.c (start_record_layout): Likewise.
1872
64510a4f
HB
18732003-01-16 Herman A.J. ten Brugge <hermantenbrugge@home.nl>
1874
07488f32 1875 * config/c4x/c4x.md (epilogue): Correct last patch.
64510a4f 1876
77480b0b
RH
18772003-01-15 Richard Henderson <rth@redhat.com>
1878
1879 * config/alpha/alpha.c (find_lo_sum_using_gp): Rename from find_lo_sum;
1880 also check that GP is being used.
1881 (alpha_find_lo_sum_using_gp): New.
1882 (alpha_does_function_need_gp): Use get_attr_usegp.
1883 * config/alpha/alpha-protos.h: Update.
1884 * config/alpha/alpha.md (attr usegp): New. Annotate patterns
1885 as needed.
1886
a0134312
RS
18872003-01-15 Roger Sayle <roger@eyesopen.com>
1888
1889 * gcse.c (one_cprop_pass): Change function arguments to take both
1890 cprop_jumps and bypass_jumps flags instead of just alter_jumps.
1891 (gcse_main): Update calls to one_cprop_pass, disabling bypassing.
1892 (bypass_jumps): New function to perform separate jump bypassing pass.
1893 * rtl.h (bypass_jumps): Add function prototype.
1894 * timevar.def (TV_BYPASS): New timing variable.
1895 * toplev.c (enum dump_file_index): Add new entry DFI_bypass.
1896 (dump_file): New entry for the bypass RTL dump file.
1897 (rest_of_compilation): Insert new jump bypassing optimization
1898 pass after loop.
1899 * doc/passes.texi: Document new pass.
1900
4af6a063
JDA
19012003-01-15 John David Anglin <dave@hiauly1.hia.nrc.ca>
1902
1903 * som.h (SUPPORTS_WEAK, SUPPORTS_ONE_ONLY, MAKE_DECL_ONE_ONLY,
1904 ASM_WEAKEN_LABEL, GTHREAD_USE_WEAK): Define.
1905 * pa.h (TARGET_SOM_SDEF): Define.
1906 * pa-hpux11.h (TARGET_SOM_SDEF): Define.
1907
51e13b71
SC
19082003-01-16 Stephane Carrez <stcarrez@nerim.fr>
1909
07488f32 1910 * config/m68hc11/m68hc11.c (expand_prologue): Use push/pop to
51e13b71
SC
1911 allocate 4-bytes of locals on 68HC11.
1912 (expand_epilogue): Likewise.
1913 (m68hc11_memory_move_cost): Increase cost of HI/QI soft registers.
1914
f077f169
SC
19152003-01-15 Stephane Carrez <stcarrez@nerim.fr>
1916
1917 * config/m68hc11/m68hc11.h (ASM_SPEC): Handle -m68hcs12; Pass -mshort
1918 and -mshort-double to the assembler to specify the ABI.
1919 (LINK_SPEC): Likewise.
1920 (CPP_SPEC): Pass HCS12 specific define.
1921 (MASK_M68S12): New define.
1922 (TARGET_M68S12): Likewise.
1923 (TARGET_SWITCHES): New options -m68hcs12 and -m68S12.
1924 (TARGET_VERSION): Update.
1925 * config/m68hc11/m68hc12.h (CPP_SPEC): Pass HCS12 specific define.
1926 (LINK_SPEC): Update.
1927 (ASM_SPEC): Update.
1928 * config/m68hc11/m68hc11.c (m68hc11_asm_file_start): Update.
1929 * doc/invoke.texi (M68hc1x Options): Document -m68hcs12.
1930
c0f684dc
SC
19312003-01-15 Stephane Carrez <stcarrez@nerim.fr>
1932
1933 * config/m68hc11/m68hc11.md ("return"): Use emit_jump_insn to emit
1934 the return code.
1935
6982ae15
JZ
19362003-01-15 Josef Zlomek <zlomekj@suse.cz>
1937
1938 * cfganal.c (set_edge_can_fallthru_flag): Clear the EDGE_CAN_FALLTHRU
1939 flag before setting it.
1940
8cadeff1
RS
19412003-01-15 Roger Sayle <roger@eyesopen.com>
1942
1943 * c-semantics.c (genrtl_while_stmt): Improve initial RTL generation
1944 when loop condition is known true, i.e. "while (1) { ... }".
1945 (genrtl_for_stmt): Similarly for "for" statements.
1946
03cd8aba
RS
19472003-01-15 Roger Sayle <roger@eyesopen.com>
1948
1949 * real.c (real_sqrt): Return a bool result indicating whether
1950 a floating point exception or trap should be raised.
1951 * real.h (real_sqrt): Update function prototype.
1952 * builtins.c (fold_builtin): Only fold non-trapping square
1953 roots unless we're ignoring errno and trapping math.
1954
4da78214
JDA
19552003-01-15 John David Anglin <dave.anglin@nrc.gc.ca>
1956
1957 * expr.h (emit_conditional_add): Add PARAMS to declaration.
1958 * gengtype-lex.l (malloc, realloc): Move defines after include of
1959 system.h. Remove duplicate include of system.h.
1960
9ee0a442
RS
19612003-01-15 Roger Sayle <roger@eyesopen.com>
1962
1963 PR middle-end/9009
1964 * optabs.c (expand_unop): When manipulating the FP sign bit
1965 using integer operations, account for targets with different
1966 integer and FP word orders.
1967 (expand_abs): Likewise.
1968
e3981aab
DE
19692003-01-15 David Edelsohn <edelsohn@gnu.org>
1970
1971 * config/rs6000/rs6000.c (rs6000_gen_section_name): Do not include
1972 file extension in section name.
1973
89c4b810
RE
19742003-01-15 Richard Earnshaw <rearnsha@arm.com>
1975
1976 * flow.c (find_auto_inc): Also try to generate a PRE_MODIFY with
1977 constant offset.
1978
3cd45774
RE
19792003-01-15 Richard Earnshaw <rearnsha@arm.com>
1980
1981 * arm.h (HAVE_PRE_MODIFY_DISP, HAVE_PRE_MODIFY_REG): Define.
1982 (HAVE_POST_MODIFY_DISP, HAVE_POST_MODIFY_REG): Define.
1983 (ARM_GO_IF_LEGITIMATE_ADDRESS): Handle pre/post-modify addresses.
1984 (ARM_PRINT_OPERAND_ADDRESS): Likewise.
1985
b1a6f8db
JH
1986Wed Jan 15 12:23:21 CET 2003 Jan Hubicka <jh@suse.cz>
1987
1988 PR f/9258
07488f32 1989 * global.c (struct allocno): Add no_stack_reg.
b1a6f8db
JH
1990 (global_conflicts): Set no_stack_reg.
1991 (find_reg): Use it.
1992
1993 * convert.c (convert_to_real): Fold - and abs only when profitable.
1994 * fold-const.c (fold): Fold truncates in - and abs.
1995
d18c7e59
JZ
19962003-01-15 Josef Zlomek <zlomekj@suse.cz>
1997
1998 Segher Boessenkool <segher@koffie.nl>
fbe3b30b
SB
1999
2000 * predict.c (real_inv_br_prob_base): New variable.
2001 (propagate_freq): Use multiply by reciprocal instead of
2002 division. Don't divide by 1.0 at all.
2003 (estimate_bb_frequencies): Similar.
2004
027faee7
AO
20052003-01-15 Alexandre Oliva <aoliva@redhat.com>
2006
2007 * configure.in (libgcc_visibility): Force disabled on IRIX 6 too.
2008 * configure: Rebuilt.
2009
077dab3b 20102003-01-15 Hartmut Penner <hpenner@de.ibm.com>
3c0121e4 2011
077dab3b
HP
2012 * config/s390/s390.c (s390_safe_attr_type): New function.
2013 (s390_use_dfa_pipeline_interface): New function, return true for z900.
2014 (s390_issue_rate): New function.
2015 (s390_agen_dep_p): New function.
2016 (addr_generation_dependency_p): Use 's390_safe_attr_type'.
2017 (s390_adjust_cost): Return 'cost' if new DFA is used.
2018 (s390_adjust_priority): Delete function.
2019 * config/s390/s390-protos.h: (s390_agen_dep_p): New prototype.
2020 * config/s390/s390.md (atype attribute): Attribute 'atype' default
2021 determined by 'op_type'.
2022 (type attribute): Added more type attributes.
2023 * config/s390/2064.md: New DFA description for z900 pipeline.
07488f32 2024
077dab3b 20252003-01-15 Alexandre Oliva <aoliva@redhat.com>
2b28d405 2026
acfa9d9f
AO
2027 * config/i386/i386.c (ix86_expand_vector_move): Validize constant
2028 forced to memory. Fixes PR bootstrap/9036.
2029
3c0121e4
AO
2030 * config/mips/mips.h (CRT_CALL_STATIC_FUNCTION): Define so as
2031 to set $gp before the call.
2032
553eb139
RH
20332003-01-14 Richard Henderson <rth@redhat.com>
2034
2035 * config/alpha/alpha.c (alpha_expand_mov): Use correct mode
2036 for force_const_mem.
2037
dd1b7476
KG
20382003-01-14 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
2039
2040 * genattr.c (main): Rearrange output to avoid prototype warning.
2041 * genautomata.c (transform_3): Fix ambiguous-else warning.
2042 * local-alloc.c (requires_inout): Add parentheses around
2043 assignment used as truth-value.
2044 * timevar.c: Move system includes above local includes. Include
2045 toplev.h
2046 * Makefile.in (timevar.o): Depend on toplev.h.
2047
6028880a
DC
20482003-01-14 Denis Chertykov <denisc@overta.ru>
2049
2050 * config/ip2k/ip2k.h (VALID_MACHINE_DECL_ATTRIBUTE): Remove.
2051 (VALID_MACHINE_TYPE_ATTRIBUTE): Remove.
2052
2053 * config/ip2k/ip2k.c (ip2k_attribute_table): New table of
07488f32 2054 attributes.
6028880a
DC
2055 (TARGET_ATTRIBUTE_TABLE): New macro.
2056 (valid_machine_type_attribute): Remove.
2057 (valid_machine_decl_attribute): Remove.
2058 (ip2k_handle_progmem_attribute): New function.
2059 (ip2k_handle_fndecl_attribute): New function.
2060
4a2953e4 20612003-01-10 Andrew Haley <aph@redhat.com>
a686ea5b
AH
2062
2063 * config/i386/linux64.h (MD_FALLBACK_FRAME_STATE_FOR): Rename
2064 registers to be in correct order. Add rip.
2065
4d77fda2
KH
20662003-01-14 Kazu Hirata <kazu@cs.umass.edu>
2067
2068 * config/h8300/h8300.md (*andsi3_lshiftrt_9_sb): New.
2069 (*iorsi3_and_lshiftrt_9_sb): Likewise.
2070
77f9af81
JH
2071Tue Jan 14 00:45:33 CET 2003 Jan Hubicka <jh@suse.cz>
2072
2073 * convert.c (strip_float_extensions): Look for narrowest type handling
2074 FP constants.
2075
2076 * fold-const.c (fold): Fold (double)float1 CMP (double)float2 into
2077 float1 CMP float2.
2078 * convert.c (strip_float_extensions): Make global.
2079 * tree.h (strip_float_extensions): Declare.
2080
fd371a93
GDR
20812003-01-14 Gabriel Dos Reis <gdr@integrable-solutions.net>
2082
2083 * timevar.def: define TV_NAME_LOOKUP.
2084 * timevar.c (timevar_pop): Be verbose when aborting.
2085
dcd1c2b8
AS
20862003-01-13 Andreas Schwab <schwab@suse.de>
2087
2088 * Makefile.in ($(parsedir)/gengtype-lex.c): Don't change to
2089 $(parsedir), just move the temporary file at the end.
2090 ($(parsedir)/gengtype-yacc.c): Likewise.
2091
eb4b5f93
AO
20922003-01-13 Alexandre Oliva <aoliva@redhat.com>
2093
2094 * aclocal.m4 (gcc_AC_PROG_GNAT): Don't try to prepend
2095 ${ac_tool_prefix} to ADAC or CC. Protect them from word
2096 splitting.
2097 * configure: Rebuilt.
2098
f7835768
KG
20992003-01-13 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
2100
2101 * config/sparc/gmon-sol2.c (moncontrol, monstartup, _mcleanup,
2102 internal_mcount): Don't use PARAMS.
2103 (monstartup, _mcleanup, internal_mcount, moncontrol): Convert to
2104 ISO C style.
2105 (internal_mcount): Use __attribute__, not ATTRIBUTE_UNUSED.
2106
38a3dbbb
AS
21072003-01-13 Andreas Schwab <schwab@suse.de>
2108
2109 * config/rs6000/sysv4.h (ASM_OUTPUT_ALIGNED_LOCAL): Output type
2110 directive.
2111
98dc53e3
KH
21122003-01-13 Kazu Hirata <kazu@cs.umass.edu>
2113
2114 * config/h8300/h8300.md (*andsi3_lshift_n_sb): New.
2115 (*iorsi3_and_lshiftrt_n_sb): Likewise.
2116
e8f2b18d
MM
21172003-01-12 Mark Mitchell <mark@codesourcery.com>
2118
2119 PR c++/9264
2120 * c-lex.c (c_lex): Set the token value to error_mark_node for
2121 invalid numeric constants.
2122
70f8b89f
KG
21232003-01-12 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
2124
2125 * c-pch.c (asm_file_startpos): Change to `long'.
2126 (pch_init): Use ftell, not ftello.
2127 (c_common_write_pch): Use ftell/fseek, not ftello/fseeko.
2128 Use `long' instead of `off_t'.
2129 (c_common_read_pch): Likewise.
2130 * ggc-common.c (gt_pch_save): Use long/ftell instead of
2131 off_t/ftello.
2132
8e37cba8
AM
21332003-01-12 Alan Modra <amodra@bigpond.net.au>
2134
2135 * expr.c (expand_expr <RDIV_EXPR>): Correct recursive call args.
2136
04f08c8e
RE
21372003-01-11 Richard Earnshaw (rearnsha@arm.com)
2138
2139 * arm-protos.h (struct cpp_reader): Add declaration.
2140
a5cf80f0
JH
2141Sat Jan 11 11:02:58 CET 2003 Jan Hubicka <jh@suse.cz>
2142
2143 PR target/9068
2144 * i386.c (output_fp_compare): Fix typo.
2145
bbfb86aa
DE
21462003-01-10 David Edelsohn <edelsohn@gnu.org>
2147
2148 * config/rs6000/rs6000.c (common_mode_defined): Mark for PCH.
2149
223b87b6
GK
21502003-01-10 Geoffrey Keating <geoffk@apple.com>
2151
3859c32a
GK
2152 * Makefile.in (parsedir): New variable.
2153 (docobjdir): New variable.
07488f32 2154 (c-parse.o, c-parse.c, c-parse.y, gengtype-lex.o, gengtype-yacc.o,
3859c32a
GK
2155 gengtype-lex.c, gengtype-yacc.c): Use parsedir.
2156 (info, cpp.info, gcc.info, gccint.info, gccinstall.info,
2157 cppinternals.info, generated-manpages, gcov.1, cpp.1, gcc.1, gfdl.7,
07488f32 2158 gpl.7, fsf-funding.7, maintainer-clean, install-info, install-man):
3859c32a
GK
2159 Use docobjdir.
2160 * objc/Make-lang.in (objc/objc-parse.c, objc/objc-parse.y,
2161 objc.maintainer-clean): Use parsedir.
2162
63af3bd1
GK
2163 * varasm.c (struct constant_descriptor_rtx): Remove unused
2164 `label' field.
2165
223b87b6
GK
2166 * toplev.c (documented_lang_options): Document -Winvalid-pch.
2167
fbadafbc
RH
21682003-01-10 Richard Henderson <rth@redhat.com>
2169
2170 * config/alpha/alpha.h (NO_PROFILE_COUNTERS): Set.
2171 (ASM_OUTPUT_REG_PUSH, ASM_OUTPUT_REG_POP): Kill.
2172
ab5ecb01
RH
21732003-01-10 Richard Henderson <rth@redhat.com>
2174
2175 * combine.c (make_compound_operation): Use SCALAR_INT_MODE_P,
2176 not INTEGRAL_MODE_P when widening extensions.
2177
7f24e7c5
RH
21782003-01-10 Richard Henderson <rth@redhat.com>
2179
2180 * config/alpha/alpha.c (decl_has_samegp): True for !TREE_PUBLIC.
2181
6dd05d08
GK
21822003-01-10 Geoffrey Keating <geoffk@apple.com>
2183
19cc0dd4
GK
2184 * ggc-page.c (ggc_collect): Avoid overflow computing
2185 min_expand.
2186
6dd05d08
GK
2187 * Makefile.in (RANLIB_FOR_TARGET): Use RANLIB when native.
2188 (RANLIB_TEST_FOR_TARGET): Delete. Don't pass down to sub-makes.
2189 Remove calls.
2190 * mklibgcc.in: Remove uses of RANLIB_TEST_FOR_TARGET.
2191
5f1355ef
JH
2192Fri Jan 10 22:05:35 CET 2003 Jan Hubicka <jh@suse.cz>
2193
2194 * ifcvt.c (noce_try_addcc): Do not call emit_conditional_add
2195 with weird operands.
2196
0cdca92b 21972003-01-10 Dale Johannesen <dalej@apple.com>
6dd05d08
GK
2198
2199 * calls.c (load_register_parameters): Add is_sibcall, sibcall_failure
2200 parameters. Call check_sibcall_argument_overlap if indicated.
2201 (check_sibcall_argument_overlap): Add mark_stored_args_map
2202 parameter. Don't mark parameter area as clobbered if not set.
2203 (expand_call): Adjust calls to above.
2204
22052003-01-10 Kelley Cook <kelleycook@comcast.net>
6cd656d0
KC
2206
2207 * configure.in (linker read-only and read-write section mixing):
2208 Squelch some assembler warnings.
2209 * configure: Likewise.
2210
be2c2a4b
HP
22112003-01-10 Hartmut Penner <hpenner@de.ibm.com>
2212
21ff35fb 2213 * doc/invoke.texi: Document -mtune, delete -mcpu
be2c2a4b
HP
2214 option for S/390 and zSeries.
2215 * config/s390/s390.c (s390_tune_string) New variable.
2216 (s390_cpu_string) Delete variable.
2217 (override_options): Use s390_tune_string instead of
2218 s390_cpu_string.
2219 * config/s390/s390.h: (TARGET_OPTIONS) '-mtune' instead of '-mcpu'.
2220
1f450138
KH
22212003-01-10 Kazu Hirata <kazu@cs.umass.edu>
2222
2223 * config/h8300/h8300.md (*iorsi3_ashift_31): New.
2224
d330ce15
JZ
22252003-01-10 Josef Zlomek <zlomekj@suse.cz>
2226
2227 * jump.c (next_nonnote_insn_in_loop): New function.
2228 (copy_loop_headers): Use next_nonnote_insn_in_loop instead of
2229 next_nonnote_insn.
2230 (duplicate_loop_exit_test). Likewise.
2231
17211ab5
GK
22322003-01-09 Geoffrey Keating <geoffk@apple.com>
2233
2234 Merge from pch-branch:
2235
2236 2003-01-06 Geoffrey Keating <geoffk@apple.com>
2237
2238 * ggc-page.c (ggc_pch_read): Update the statistics after a PCH
2239 load.
2240
2241 2002-12-24 Geoffrey Keating <geoffk@apple.com>
2242
2243 * cpplib.c (count_registered_pragmas): New function.
2244 (save_registered_pragmas): New function.
2245 (_cpp_save_pragma_names): New function.
2246 (restore_registered_pragmas): New function.
2247 (_cpp_restore_pragma_names): New function.
2248 * cpphash.h (_cpp_save_pragma_names): Prototype.
2249 (_cpp_restore_pragma_names): Likewise.
2250 * cpppch.c (struct save_macro_item): Split from save_macro_data.
2251 (struct save_macro_data): New field 'saved_pragmas'.
2252 (save_macros): Update for changes to struct save_macro_data.
2253 (cpp_prepare_state): Call _cpp_save_pragma_names, update
2254 for changes to struct save_macro_data.
2255 (cpp_read_state): Call _cpp_restore_pragma_names, update
2256 for changes to struct save_macro_data.
2257
2258 * cpppch.c (cpp_read_state): Restore the hashtable references
2259 in the cpp_reader.
07488f32 2260
17211ab5
GK
2261 * tree.h (built_in_decls): Mark for PCH.
2262
2263 * dbxout.c (lastfile): Don't mark for PCH.
2264
2265 * ggc.h: Document PCH calls into memory managers.
2266
2267 2002-12-18 Geoffrey Keating <geoffk@apple.com>
2268
2269 * doc/invoke.texi (Precompiled Headers): Document the
2270 directory form of PCH.
2271 * cppfiles.c (validate_pch): New function.
2272 (open_file_pch): Search suitably-named directories for PCH files.
2273
2274 2002-12-14 Geoffrey Keating <geoffk@apple.com>
2275
2276 * doc/gty.texi (GTY Options): Document chain_next, chain_prev,
2277 reorder options.
2278 (Type Information): Mention that the information is also
2279 used to implement PCH.
2280 * doc/passes.texi (Passes): Improve documentation of
2281 language-specific files.
2282
2283 2002-12-11 Geoffrey Keating <geoffk@apple.com>
2284
2285 * gengtype.c (struct write_types_data): Add reorder_note_routine field.
2286 (struct walk_type_data): Add reorder_fn field.
2287 (walk_type): Process 'reorder' option.
2288 (write_types_process_field): Reorder parameters to gt_pch_note_object,
2289 call reorder_note_routine.
2290 (write_func_for_structure): Reorder parameters to gt_pch_note_object.
2291 (ggc_wtd): Update for change to struct write_types_data.
2292 (pch_wtd): Likewise.
2293 * ggc.h (gt_pch_note_object): Reorder parameters.
2294 (gt_handle_reorder): New definition.
2295 (gt_pch_note_reorder): New prototype.
2296 * ggc-common.c (struct ptr_data): Add reorder_fn.
2297 (gt_pch_note_object): Reorder parameters.
2298 (gt_pch_note_reorder): New.
2299 (gt_pch_save): Call reorder_fn.
2300 * stringpool.c (gt_pch_n_S): Update for change to gt_pch_note_object.
2301
2302 * dbxout.c (cwd): Don't mark for PCH.
2303
2304 2002-12-09 Geoffrey Keating <geoffk@apple.com>
2305
2306 * gengtype.c (finish_root_table): Fix some warnings.
2307 (write_root): Handle TYPE_STRING.
2308 * ggc.h (gt_ggc_m_S): Add prototype.
2309 * stringpool.c (gt_ggc_m_S): New function.
2310
2311 2002-11-30 Geoffrey Keating <geoffk@apple.com>
2312
2313 * dwarf2out.c (dw2_string_counter): New.
2314 (AT_string_form): Use it.
2315 (same_dw_val_p): Update for removal of hashtable.h hash tables.
2316
2317 2002-11-22 Geoffrey Keating <geoffk@apple.com>
2318
2319 * dbxout.c: Include gt-dbxout.h.
2320 (lastfile): Mark for PCH/GGC.
2321 (cwd): Likewise.
2322 (struct typeinfo): Likewise.
2323 (typevec): Likewise.
2324 (typevec_len): Likewise.
2325 (next_type_number): Likewise.
2326 (struct dbx_file): Likewise.
2327 (current_file): Likewise.
2328 (next_file_number): Likewise.
2329 (dbxout_init): Allocate typevec, struct dbx_file with GGC.
2330 (dbxout_start_source_file): Allocate struct dbx_file with GGC.
2331 (dbxout_end_source_file): Don't free struct dbx_file.
2332 (dbxout_type): Use GGC to allocate typevec.
2333 * Makefile.in (dbxout.o): Depend on gt-dbxout.h, $(GGC_H).
2334 (GTFILES): Add dbxout.c.
2335 (gt-dbxout.h): New rule.
07488f32 2336
17211ab5
GK
2337 * Makefile.in (c-pch.o): Add debug.h as dependency.
2338 * c-pch.c: Include debug.h.
2339 (pch_init): Call start_source_file to keep nesting right.
2340 (c_common_read_pch): Add orig_name parameter. Call
2341 start_source_file debug hook. Call end_source_file debug hook.
2342 * c-common.h (c_common_read_pch): Update prototype.
2343 * cpplib.h (struct cpp_callbacks): Add fourth field to read_pch
2344 callback.
2345 * cppfiles.c (struct include_file): Add new field `header_name'.
2346 (find_or_create_entry): Default it to `name'.
2347 (open_file_pch): Set it to the original header file searched for.
2348 (stack_include_file): Don't stack an empty buffer, just handle
2349 PCH files immediately. Pass header_name field to read_pch callback.
2350
2351 2002-11-19 Geoffrey Keating <geoffk@apple.com>
2352
2353 * function.c (funcdef_no): Mark to be saved in a PCH.
2354
2355 2002-11-15 Geoffrey Keating <geoffk@apple.com>
2356
2357 * ggc-page.c (ggc_pch_read): Remove unused 'bmap_size'.
2358
2359 * cpppch.c (cpp_read_state): Correct size reallocated for 'defn'.
2360
2361 2002-11-14 Geoffrey Keating <geoffk@apple.com>
2362
2363 * optabs.h (code_to_optab): Add GTY marker.
2364
2365 2002-11-13 Geoffrey Keating <geoffk@apple.com>
2366
2367 * Makefile.in (GTFILES): Add cpplib.h.
2368 * c-common.h (struct c_common_identifier): Don't skip 'node' field.
2369 * c-decl.c (build_compound_literal): Don't use var_labelno.
2370 * cpplib.h (struct cpp_hashnode): Use gengtype to mark.
2371 * dwarf2asm.c (dw2_force_const_mem): Don't use const_labelno.
2372 * varasm.c (const_labelno): Use gengtype to mark.
2373 (var_labelno): Likewise.
2374 (in_section): Likewise.
2375 (in_named_name): Likewise.
2376 (struct in_named_entry): Likewise.
2377 (in_named_htab): Likewise.
2378 (set_named_section_flags): Use GGC to allocate struct in_named_entry.
2379 (init_varasm_once): Use GGC to allocate in_named_htab.
2380 * config/darwin.c (current_pic_label_num): Mark for PCH.
2381
2382 2002-11-11 Geoffrey Keating <geoffk@apple.com>
2383
2384 * ggc-simple.c (init_ggc_pch): New stub procedure.
2385 (ggc_pch_count_object): Likewise.
2386 (ggc_pch_total_size): Likewise.
2387 (ggc_pch_this_base): Likewise.
2388 (ggc_pch_alloc_object): Likewise.
2389 (ggc_pch_prepare_write): Likewise.
2390 (ggc_pch_write_object): Likewise
2391 (ggc_pch_finish): Likewise.
2392 (ggc_pch_read): Likewise.
2393
2394 2002-11-08 Geoffrey Keating <geoffk@apple.com>
2395
2396 * c-pch.c (c_common_write_pch): Write the macro definitions after
2397 the GCed data.
2398 (c_common_read_pch): Call cpp_prepare_state. Restore the macro
2399 definitions after the GCed data.
2400 * cpplib.c (save_macros): New.
2401 (reset_ht): New.
2402 (cpp_write_pch_deps): Split out of cpp_write_pch.
2403 (cpp_write_pch_state): Split out of cpp_write_pch.
2404 (cpp_write_pch): Delete.
2405 (struct save_macro_data): Delete.
2406 (cpp_prepare_state): New.
2407 (cpp_read_state): Erase and restore initial macro definitions.
2408 * cpplib.h (struct save_macro_data): Forward-declare.
2409 (cpp_write_pch_deps): Prototype.
2410 (cpp_write_pch_state): Prototype.
2411 (cpp_write_pch): Delete prototype.
2412 (cpp_prepare_state): Prototype.
2413 (cpp_read_state): Add fourth argument.
2414
2415 2002-11-04 Geoffrey Keating <geoffk@apple.com>
2416
2417 * gengtype.c (adjust_field_rtx_def): Don't use skip on valid fields.
2418 (write_array): Remove warning.
2419
2420 * gengtype.c (contains_scalar_p): New.
2421 (finish_root_table): Add the table to all languages, even if it's
2422 empty.
2423 (write_roots): Output gt_pch_scalar_rtab.
2424 * ggc-common.c (gt_pch_save): Write out scalars.
2425 (gt_pch_restore): Read scalars back.
2426
2427 * ggc-page.c (OBJECTS_IN_PAGE): New macro.
2428 (struct page_entry): Delete pch_page field.
2429 (ggc_recalculate_in_use_p): Use OBJECTS_IN_PAGE.
2430 (clear_marks): Likewise.
2431 (sweep_pages): Likewise.
2432 (poison_pages): Likewise.
2433 (ggc_print_statistics): Likewise.
2434 (ggc_pch_read): Don't free objects read from a PCH.
2435 Properly set up in_use_p and page_tails.
2436
2437 2002-10-25 Geoffrey Keating <geoffk@apple.com>
2438
2439 * gengtype.c (struct write_types_data): New.
2440 (struct walk_type_data): Make `cookie' const; add extra
2441 prev_val item; add `orig_s' field.
2442 (walk_type): Update prev_val[3].
2443 (write_types_process_field): New.
2444 (write_func_for_structure): Take write_types_data structure.
2445 (write_types): New.
2446 (ggc_wtd): New.
2447 (pch_wtd): New.
2448 (write_types_local_process_field): New.
2449 (gc_mark_process_field): Delete.
2450 (write_local_func_for_structure): New.
2451 (gc_mark_func_name): Delete.
2452 (write_gc_types): Delete.
2453 (write_local): New.
2454 (finish_root_table): Don't include 'ggc_' in PFX.
2455 (write_root): Rename from write_root. Fill pchw field of structures.
2456 (write_array): New.
2457 (write_roots): Rename from write_gc_roots. Split out to write_array.
2458 Update to changes to other routines. Write gt_pch_cache_rtab table.
2459 (main): Write PCH walking routines.
2460 * ggc-common.c: Include toplev.h, sys/mman.h.
2461 (ggc_mark_roots): For cache hashtables, also mark the hash table
2462 and the array of entries.
2463 (saving_htab): New.
2464 (struct ptr_data): New.
2465 (POINTER_HASH): New.
2466 (gt_pch_note_object): New.
2467 (saving_htab_hash): New.
2468 (saving_htab_eq): New.
2469 (struct traversal_state): New.
2470 (call_count): New.
2471 (call_alloc): New.
2472 (compare_ptr_data): New.
2473 (relocate_ptrs): New.
2474 (write_pch_globals): New.
2475 (struct mmap_info): New.
2476 (gt_pch_save): New.
2477 (gt_pch_restore): New.
2478 * ggc-page.c (ROUND_UP_VALUE): New.
2479 (ROUND_UP): New.
2480 (struct page_entry): Add field `pch_page'.
2481 (init_ggc): Use ROUND_UP.
2482 (struct ggc_pch_data): Declare.
2483 (init_ggc_pch): New.
2484 (ggc_pch_count_object): New.
2485 (ggc_pch_total_size): New.
2486 (ggc_pch_this_base): New.
2487 (ggc_pch_alloc_object): New.
2488 (ggc_pch_prepare_write): New.
2489 (ggc_pch_write_object): New.
2490 (ggc_pch_finish): New.
2491 (ggc_pch_read): New.
2492 * ggc.h (gt_pointer_operator): New.
2493 (gt_note_pointers): New.
2494 (gt_pch_note_object): New prototype.
2495 (gt_pointer_walker): New.
2496 (struct ggc_root_tab): Use gt_pointer_walker, add `pchw' field.
2497 (LAST_GGC_ROOT_TAB): Update.
2498 (gt_pch_cache_rtab): Declare.
2499 (gt_pch_scalar_rtab): Declare.
2500 (struct ggc_cache_tab): Use gt_pointer_walker, add `pchw' field.
2501 (LAST_GGC_CACHE_TAB): Update.
2502 (gt_pch_save_stringpool): Declare.
2503 (gt_pch_restore_stringpool): Declare.
2504 (gt_pch_p_S): Declare.
2505 (gt_pch_n_S): Declare.
2506 (struct ggc_pch_data): Forward-declare.
2507 (init_ggc_pch): Declare.
2508 (ggc_pch_count_object): Declare.
2509 (ggc_pch_total_size): Declare.
2510 (ggc_pch_this_base): Declare.
2511 (ggc_pch_alloc_object): Declare.
2512 (ggc_pch_prepare_write): Declare.
2513 (ggc_pch_write_object): Declare.
2514 (ggc_pch_finish): Declare.
2515 (ggc_pch_read): Declare.
2516 (gt_pch_save): Declare.
2517 (gt_pch_restore): Declare.
2518 * fold-const.c (size_int_type_wide): Allocate size_htab using GGC.
2519 * emit-rtl.c (init_emit_once): Allocate const_int_htab,
2520 const_double_htab, mem_attrs_htab using GGC.
2521 * c-pch.c: Include ggc.h.
2522 (pch_init): Allow reading PCH file back.
2523 (c_common_write_pch): Call gt_pch_save.
2524 (c_common_read_pch): Call gt_pch_restore.
2525 * c-parse.in (init_reswords): Delete now-untrue comment.
2526 Allocate ridpointers using GGC.
2527 * c-objc-common.c (c_objc_common_finish_file): Write PCH before
2528 calling expand_deferred_fns.
2529 * c-common.h (ridpointers): Mark for GTY machinery.
2530 * Makefile.in (stringpool.o): Update dependencies.
2531 (c-pch.o): Update dependencies.
2532 (ggc-common.o): Update dependencies.
2533 * stringpool.c: Include gt-stringpool.h.
2534 (gt_pch_p_S): New.
2535 (gt_pch_n_S): New.
2536 (struct string_pool_data): New.
2537 (spd): New.
2538 (gt_pch_save_stringpool): New.
2539 (gt_pch_restore_stringpool): New.
2540 * tree.c (init_ttree): Make type_hash_table allocated using GC.
07488f32 2541
17211ab5
GK
2542 2002-10-04 Geoffrey Keating <geoffk@apple.com>
2543
2544 * gengtype.c (adjust_field_rtx_def): Don't pass size_t to printf.
2545 (output_mangled_typename): Don't pass size_t to printf.
2546
2547 * tree.h (union tree_type_symtab): Add tag to `address' field.
2548 (union tree_decl_u2): Add tag to 'i' field.
2549 * varasm.c (union rtx_const_un): Add tags to all fields.
2550 * gengtype.c (struct walk_type_data): New.
2551 (output_escaped_param): Take struct walk_type_data parameter.
2552 (write_gc_structure_fields): Delete.
2553 (walk_type): New.
2554 (write_gc_marker_routine_for_structure): Delete.
2555 (write_func_for_structure): New.
2556 (gc_mark_process_field): New.
2557 (gc_mark_func_name): New.
2558 (gc_counter): Delete.
2559 (write_gc_types): Use write_func_for_structure.
2560 (write_gc_roots): Use walk_type.
2561
2562 2002-10-02 Geoffrey Keating <geoffk@apple.com>
2563
2564 * ggc-common.c (ggc_mark_roots): Delete 'x'.
2565 (ggc_splay_dont_free): Fix warning about unused 'x'.
2566 (ggc_print_common_statistics): Remove warnings.
2567
2568 2002-10-01 Mike Stump <mrs@apple.com>
2569
07488f32
ZW
2570 * ggc-common.c (ggc_splay_alloc): Actually return the allocated area.
2571 * gengtype.c (write_gc_structure_fields): Handle param[digit]_is.
17211ab5
GK
2572
2573 2002-09-01 Geoffrey Keating <geoffk@redhat.com>
2574 Catherine Moore <clm@redhat.com>
2575
2576 * Makefile (c-pch.o): Update dependencies.
2577 (LIBCPP_OBJS): Add cpppch.o.
2578 (cpppch.o): New.
2579 * c-common.c (c_common_init): Don't call pch_init here.
2580 * c-common.h (c_common_read_pch): Update prototype.
2581 * c-lex.c (c_common_parse_file): Call pch_init here.
2582 * c-opts.c (COMMAND_LINE_OPTIONS): Add -Winvalid-pch, -fpch-deps.
2583 (c_common_decode_option): Handle them.
2584 * c-pch.c: Include c-pragma.h.
2585 (save_asm_offset): Delete.
2586 (pch_init): Move contents of save_asm_offset into here, call
2587 cpp_save_state.
2588 (c_common_write_pch): Call cpp_write_pch.
2589 (c_common_valid_pch): Warn only when -Winvalid-pch. Call
2590 cpp_valid_state.
2591 (c_common_read_pch): Add NAME parameter. Call cpp_read_state.
07488f32 2592 * cppfiles.c (stack_include_file): Update for change to
17211ab5
GK
2593 parameters of cb.read_pch.
2594 * cpphash.h (struct cpp_reader): Add `savedstate' field.
2595 * cpplib.h (struct cpp_options): Add `warn_invalid_pch' and
2596 `restore_pch_deps' fields.
2597 (struct cpp_callbacks): Add NAME parameter to `read_pch'.
2598 (cpp_save_state): Prototype.
2599 (cpp_write_pch): Prototype.
2600 (cpp_valid_state): Prototype.
2601 (cpp_read_state): Prototype.
2602 * cpppch.c: New file.
2603 * flags.h (version_flag): Remove prototype.
2604 * mkdeps.c (deps_save): New.
2605 (deps_restore): New.
2606 * mkdeps.h (deps_save): Prototype.
2607 (deps_restore): Prototype.
2608 * toplev.c (late_init_hook): Delete.
2609 (version_flag): Make static again.
2610 (compile_file): Don't call late_init_hook.
2611 * toplev.h (late_init_hook): Delete.
2612 * doc/cppopts.texi: Document -fpch-deps.
2613 * doc/invoke.texi (Warning Options): Document -Winvalid-pch.
2614
2615 2002-08-27 Geoffrey Keating <geoffk@redhat.com>
2616
2617 * c-pch.c (c_common_write_pch): Rename from c_write_pch, change
2618 callers.
2619 (c_common_valid_pch): Rename from c_valid_pch, change callers.
2620 (c_common_read_pch): Rename from c_read_pch, change callers.
2621
2622 * c-opts.c (COMMAND_LINE_OPTIONS): Allow -output-pch= to have
2623 a space between it and its argument.
2624
2625 2002-08-24 Geoffrey Keating <geoffk@redhat.com>
2626
2627 * c-pch.c: New file.
2628 * toplev.h (late_init_hook): Declare.
2629 * toplev.c (late_init_hook): Define.
2630 (version_flag): Make globally visible.
2631 (compile_file): Call late_init_hook.
2632 (init_asm_output): Make output file seekable.
2633 * gcc.c (default_compilers): Update c-header rule.
2634 * flags.h (version_flag): Declare.
2635 * cpplib.h (struct cpp_callbacks): Add 'valid_pch' and 'read_pch'
2636 fields.
2637 * cppfiles.c (struct include_file): Add 'pch' field.
2638 (INCLUDE_PCH_P): New.
2639 (open_file_pch): New.
2640 (stack_include_file): Handle PCH files specially.
2641 (find_include_file): Call open_file_pch instead of open_file.
2642 (_cpp_read_file): Explain why open_file is used instead of
2643 open_file_pch.
2644 * c-opts.c (c_common_decode_option): Correct OPT__output_pch case.
2645 * c-objc-common.c (c_objc_common_finish_file): Call c_write_pch.
2646 * c-lex.c (init_c_lex): Set valid_pch and read_pch fields
2647 in cpplib callbacks.
2648 * c-common.c (pch_file): Correct comment.
2649 (allow_pch): Define.
2650 (c_common_init): Call pch_init.
2651 * c-common.h (allow_pch): Declare.
2652 (pch_init): Declare.
2653 (c_valid_pch): Declare.
2654 (c_read_pch): Declare.
2655 (c_write_pch): Declare.
2656 * Makefile.in (c-pch.o): New.
2657 (C_AND_OBJC_OBJS): Add c-pch.o.
2658 * doc/invoke.texi (Precompiled Headers): Add index entries,
2659 complete truncated paragraph.
2660
2661 2002-08-17 Geoffrey Keating <geoffk@redhat.com>
2662
2663 * c-common.c: (pch_file): Define.
2664 * c-common.h (pch_file): Declare.
2665 * c-opts.c (COMMAND_LINE_OPTIONS): Add --output-pch=.
2666 (missing_arg): Require --output-pch= to have an argument.
2667 (c_common_decode_option): Handle --output-pch=.
2668 * gcc.c: Document new %V.
2669 (default_compilers): Handle compiling C header files.
2670 (do_spec_1): Implement %V.
2671 (main): Handle "gcc foo.h" without trying to run linker.
2672 * doc/invoke.texi (Invoking GCC): Add new menu item for PCH.
2673 (Overall Options): Document what the driver does with header files,
2674 document new -x option possibilities.
2675 (Invoking G++): More documentation for PCH.
2676 (Precompiled Headers): New.
2677
2678 2002-08-09 Geoffrey Keating <geoffk@redhat.com>
2679
2680 * ggc.h: Don't include varray.h. Rearrange functions to be more
2681 organized.
2682 (ggc_add_root): Delete.
2683 (ggc_mark_rtx): Delete.
2684 (ggc_mark_tree): Delete.
2685 (struct ggc_statistics): Remove contents.
2686 * ggc-common.c: Remove unneeded includes.
2687 (struct ggc_root): Delete.
2688 (roots): Delete.
2689 (ggc_add_root): Delete.
2690 (ggc_mark_roots): Don't mark `roots'. Call ggc_mark_stringpool.
2691 (ggc_print_common_statistics): Remove most of the contents.
2692 * Makefile.in (GGC_H): No longer uses varray.h.
2693 (ggc-common.o): Update dependencies.
2694 (c-parse.o): Add varray.h to dependencies.
2695 (c-common.o): Add varray.h.
2696 * stringpool.c (mark_ident): Use mangled name for tree marker routine.
2697 (mark_ident_hash): Rename to ggc_mark_stringpool.
2698 (init_stringpool): Don't use ggc_add_root.
2699 * c-parse.in: Include varray.h.
2700 * c-common.c: Include varray.h.
2701 * objc/Make-lang.in (objc-act.o): Add varray.h.
2702 * objc/objc-act.c: Include varray.h.
2703
2704 2002-07-25 Geoffrey Keating <geoffk@redhat.com>
2705
2706 * dwarf2out.c (dw_cfi_oprnd2_desc): Fix ISO-only function definition.
2707 (dw_cfi_oprnd1_desc): Likewise.
2708
2709 2002-07-17 Geoffrey Keating <geoffk@redhat.com>
2710
2711 * config/alpha/alpha.c (struct alpha_links): Use gengtype to mark;
2712 move out of ifdef.
2713 (alpha_links): Use gengtype to mark; move out of ifdef.
2714 (mark_alpha_links_node): Delete.
2715 (mark_alpha_links): Delete.
2716 (alpha_need_linkage): Use GGC to allocate splay tree, struct
2717 alpha_links, strings. Don't use ggc_add_root.
2718 * ggc-common.c (ggc_splay_alloc): New.
2719 (ggc_splay_dont_free): New.
2720 * ggc.h (ggc_mark_rtx): Update for changed name mangling.
2721 (ggc_mark_tree): Likewise.
2722 (splay_tree_new_ggc): New.
2723 (ggc_splay_alloc): Declare.
2724 (ggc_splay_dont_free): Declare.
2725 * dwarf2asm.c: Include gt-dwarf2asm.h.
2726 (mark_indirect_pool_entry): Delete.
2727 (mark_indirect_pool): Delete.
2728 (indirect_pool): Use gengtype to mark.
2729 (dw2_force_const_mem): Don't use ggc_add_root.
2730 * Makefile.in (dwarf2asm.o): Depend on gt-dwarf2asm.h.
2731 (GTFILES): Add SPLAY_TREE_H, dwarf2asm.c.
2732 (gt-dwarf2asm.h): Depend on s-gtype.
2733
2734 2002-07-08 Geoffrey Keating <geoffk@redhat.com>
2735
2736 * tree.h (union tree_type_symtab): Mark `die' field.
2737 * Makefile.in (dwarf2out.o): Update dependencies.
2738 * dwarf2out.c: Use GGC to allocate all structures. Convert to htab_t
2739 hash tables.
2740 (dw_cfi_oprnd1_desc): New function.
2741 (dw_cfi_oprnd2_desc): New function.
2742 (indirect_string_alloc): Delete.
2743 (debug_str_do_hash): New function.
2744 (debug_str_eq): New function.
2745 (mark_limbo_die_list): Delete.
2746 (dwarf2out_init): Don't call ggc_add_root.
2747
30028c85
VM
27482003-01-09 Vladimir Makarov <vmakarov@redhat.com>
2749
2750 The following changes are merged from itanium-sched-branch:
2751
2752 2003-01-08 David Edelsohn <edelsohn@gnu.org>
2753
2754 * doc/md.texi: Clarify assignment of units to automata description.
2755
2756 2003-01-08 Vladimir Makarov <vmakarov@redhat.com>
2757
2758 * genautomata.c (unit_decl): Remove members
2759 `the_same_automaton_unit' and
2760 `the_same_automaton_message_reported_p'.
2761 (process_unit_to_form_the_same_automaton_unit_lists,
2762 form_the_same_automaton_unit_lists_from_regexp,
2763 form_the_same_automaton_unit_lists, the_same_automaton_lists):
2764 Remove them.
2765 (annotation_message_reported_p): New global variable.
2766 (check_unit_distribution_in_reserv,
2767 check_regexp_units_distribution): New functions.
2768 (check_unit_distributions_to_automata): Rewrite it.
2769
2770 2003-01-04 Vladimir Makarov <vmakarov@redhat.com>
2771
2772 * genautomata.c (form_the_same_automaton_unit_lists_from_regexp):
2773 Use continue instead of break if cycle is too big.
2774
2775 2002-12-20 Vladimir Makarov <vmakarov@redhat.com>
2776
2777 * genautomata.c (check_unit_distributions_to_automata): Output at
2778 most one message for a unit.
2779 (process_unit_to_form_the_same_automaton_unit_lists): Check
2780 automaton of units instead of units themself.
2781
2782 * doc/md.texi: Describe the constraint about assigning unit to
2783 automata.
2784
2785 2002-12-20 Jan Hubicka <jH@suse.cz>
2786 Vladimir Makarov <vmakarov@redhat.com>
2787
2788 * genautomata.c (unit_decl): Add new members `min_occ_cycle_num'
2789 and `in_set_p'.
2790 (gen_cpu_unit): Initialize the new members.
2791 (process_regexp_cycles): Calculate minimal finish cycle too. Set
2792 up `min_occ_cycle_num'.
2793 (evaluate_max_reserv_cycles): Change the function call.
2794 (CLEAR_BIT): New macro.
2795 (states_union, state_shift): Use the mask.
2796 (initiate_excl_sets, form_reserv_sets_list): Set up `in_set_p'.
2797 (form_reservs_matter): New function.
2798 (make_automaton): Call the function and use the mask.
2799 (estimate_one_automaton_bound): Take `min_occ_cycle_num' into
2800 account.
07488f32 2801
30028c85
VM
2802 2002-12-17 Vladimir Makarov <vmakarov@redhat.com>
2803
2804 * config/ia64/itanium2.md (lfetch): Change the insn reservation.
2805
2806 2002-12-17 Vladimir Makarov <vmakarov@redhat.com>
2807
2808 * config/ia64/ia64.c (bundling): Try to insert 2 nops for M insn
2809 for Itanium.
2810
2811 2002-12-17 Vladimir Makarov <vmakarov@redhat.com>
2812
2813 * config/ia64/ia64.c (ia64_override_options): Make itanium2 as
2814 default cpu.
2815
2816 2002-12-17 Vladimir Makarov <vmakarov@redhat.com>
2817 2002-10-31 Dale Johannesen <dalej@apple.com>
2818
2819 * haifa-sched.c (find_set_reg_weight): New function.
2820 (find_insn_reg_weight): Use the new function.
2821 (schedule_block): Do sorting ready queue always
2822 after insn issue.
2823
2824 2002-11-27 Vladimir Makarov <vmakarov@redhat.com>
2825
2826 * config/ia64/ia64.c (bundling): Use MFI template instead of MLX.
2827
2828 2002-11-19 Vladimir Makarov <vmakarov@redhat.com>
2829
2830 * haifa-sched.c (choice_entry): New structure.
2831 (choice_stack, cycle_issued_insns): New variables.
2832 (max_issue): Rewrite it.
2833 (choose_ready): Set up ready_try for unknown insns too.
2834 (schedule_block): Allocate and free choice_stack. Set up
2835 and modify cycle_issued_insns.
2836
2837 * config/ia64/ia64.c (issue_nops_and_insn): Combine insn issue
2838 with and without filling the bundle.
2839 (bundling): Combine calls of issue_nops_and_insn.
07488f32 2840
30028c85
VM
2841 2002-10-17 Vladimir Makarov <vmakarov@redhat.com>
2842
2843 * config/ia64/itanium1.md: New file.
2844
2845 * config/ia64/itanium2.md: New file.
2846
2847 * config/ia64/ia64.md: Move DFA descriptions into the new files.
2848 Remove the old pipeline description.
07488f32 2849
30028c85
VM
2850 * config/ia64/ia64.c (ia64_override_options): Add aliases of
2851 itanium processor names.
07488f32 2852
30028c85
VM
2853 2002-10-16 Vladimir Makarov <vmakarov@redhat.com>
2854
2855 * config/ia64/ia64.c (bundling): Print states for Itanium2 too.
2856 (ia64_reorg): Set up queried unit codes for Itanium2 too.
2857
2858 * config/ia64/ia64.md: Add descriptions for Itanium2.
2859
2860 2002-10-08 Vladimir Makarov <vmakarov@redhat.com>
2861
2862 * config/ia64/ia64.h (processor_type): New enumeration.
2863 (ia64_tune, ia64_tune_string): New external declarations.
2864 (TARGET_OPTIONS): Add option `tune='.
2865
2866 * config/ia64/ia64.c (ia64_tune, ia64_tune_string): New global
2867 variables.
2868 (ia64_override_options): Set up `ia64_tune'.
2869 (ia64_sched_reorder2): Set up `clocks' only for Itanium.
2870 (ia64_dfa_new_cycle): Set up `add_cycles' only for Itanium.
2871 (bundling): Add nops for MM-insns only for Itanium.
2872 (ia64_reorg): Allocate and free `clocks' and `add_cycles' only for
2873 Itanium.
2874
2875 * config/ia64/ia64.md (cpu): New attribute.
2876 (DFA description): Enable it only for Itanium.
07488f32 2877
30028c85
VM
2878 2002-10-08 Vladimir Makarov <vmakarov@redhat.com>
2879 Richard Henderson <rth@redhat.com>
2880
2881 * config/ia64/ia64.h (MASK_TUNE_STOP_BITS): Rename it to
2882 MASK_EARLY_STOP_BITS.
2883 (TARGET_TUNE_STOP_BITS): Rename it to TARGET_EARLY_STOP_BITS.
2884 (TARGET_SWITCHES): Rename option `tune-stop-bits' to
2885 `early-stop-bits'.
07488f32 2886
30028c85
VM
2887 * config/ia64/ia64.c (ia64_dfa_new_cycle,
2888 final_emit_insn_group_barriers): Use TARGET_EARLY_STOP_BITS
2889 instead of TARGET_TUNE_STOP_BITS.
07488f32 2890
30028c85
VM
2891 * doc/invoke.texi: Rename option `-mtune-stop-bits' to
2892 `-mearly-stop-bits'.
2893
2894 * config/ia64/ia64.c (automata_option "v"): Comment it.
07488f32 2895
30028c85
VM
2896 2002-10-07 Vladimir Makarov <vmakarov@redhat.com>
2897
07488f32 2898 * config/ia64/ia64.h (MASK_TUNE_STOP_BITS, TARGET_TUNE_STOP_BITS):
30028c85
VM
2899 New macros.
2900 (TARGET_SWITCHES): Add entries for the new option.
07488f32 2901
30028c85
VM
2902 * config/ia64/ia64.c (dfa_stop_insn, last_scheduled_insn, rtx
2903 dfa_pre_cycle_insn, ia64_nop): Don't make them as roots for GC.
2904 (stops_p, stop_before_p, clocks_length, clocks, add_cycles): New
2905 global variables.
2906 (ia64_sched_reorder2): Set up `clocks'.
2907 (ia64_variable_issue): Set up `stops_p' and reset `stop_before_p'.
2908 (ia64_dfa_new_cycle): Set up add_cycle. Permit sorting ready
2909 queue when TARGET_TUNE_STOP_BITS.
2910 (bundling): Insert additional nops for MM-insns.
2911 (final_emit_insn_group_barriers): Add insertion of stop bits
2912 according `stops_p'.
2913 (ia64_reorg): Initiate the new varibales.
2914
2915 * doc/invoke.texi: Add description of option `-mtune-stop-bits'.
07488f32 2916
30028c85
VM
2917 2002-10-02 Vladimir Makarov <vmakarov@redhat.com>
2918
2919 * haifa-sched.c (schedule_block): Modify INSN_TICK of depended
2920 insns at the end of block insn scheduling.
2921
2922 2002-09-30 Vladimir Makarov <vmakarov@redhat.com>
2923
2924 * sched-deps.c (remove_dependence, group_leader): Remove it.
2925 (add_dependence): Add dependence to group leader to.
2926 (set_sched_group_p): Add dependence to the first insn of the
2927 schedule group too.
2928 (sched_analyze_insn): Make dependence to jump as anti-dependence.
2929 Change true dependence by anti-dependence when
2930 `reg_pending_barrier'.
2931
2932 * sched-rgn.c (init_ready_list, can_schedule_ready_p,
2933 add_branch_dependences): Ignore schedule groups.
2934
2935 * sched-ebb.c (init_ready_list): Ditto.
2936
2937 * (move_insn, set_priorities): Ditto.
2938
2939 * config/ia64/ia64.c (ia64_sched_init): Check that schedule group
2940 flag is clear after reload.
2941 (adjust_cost): Change cost only for output dependencies.
07488f32 2942
30028c85 2943 * config/ia64/ia64.md: Add more insns into bypass for MM-insns.
07488f32 2944
30028c85
VM
2945 2002-09-26 Vladimir Makarov <vmakarov@redhat.com>
2946
2947 * Makefile.in (sched-ebb.o): Add `$(TARGET_H)' to the entry.
2948
2949 * target.h (gcc_target): Add member
2950 `dependencies_evaluation_hook'.
2951
2952 * target-def.h (TARGET_SCHED_DEPENDENCIES_EVALUATION_HOOK): New
2953 macro.
2954 (TARGET_SCHED): Add initiatialization of the new member.
2955
2956 * sched-ebb.c: Include `target.h'.
2957 (schedule_ebb): Call `dependencies_evaluation_hook'.
2958
2959 * sched-rgn.c (schedule_region): Call
2960 `dependencies_evaluation_hook'.
2961
2962 * config/ia64/ia64.c (TARGET_SCHED_DEPENDENCIES_EVALUATION_HOOK):
2963 New macro.
2964 (ia64_dependencies_evaluation_hook): New function.
2965
2966 * doc/tm.texi (TARGET_SCHED_DEPENDENCIES_EVALUATION_HOOK):
2967 Describe the new hook.
07488f32 2968
30028c85
VM
2969 2002-09-25 Vladimir Makarov <vmakarov@redhat.com>
2970
2971 * target.h (gcc_target): Add members
2972 `first_cycle_multipass_dfa_lookahead_guard' and `dfa_new_cycle'.
2973
2974 * target-def.h (TARGET_SCHED_DFA_NEW_CYCLE,
2975 TARGET_SCHED_FIRST_CYCLE_MULTIPASS_DFA_LOOKAHEAD_GUARD): New
2976 macros.
2977 (TARGET_SCHED): Add initiatialization of the new members.
2978
2979 * haifa-sched.c (schedule_insn): Update last_clock_var for the 1st
2980 insn scheduling too.
2981 (choose_ready): Use `first_cycle_multipass_dfa_lookahead_guard' to
2982 initialize `ready_try'.
2983 (schedule_block): Use `dfa_new_cycle'. Sort `ready' only unless
2984 `dfa_new_cycle' says not to do it.
07488f32 2985
30028c85
VM
2986 * config/ia64/ia64.md: Add DFA Itanium 1 description for insn
2987 bundling.
2988
2989 * config/ia64/ia64.h (CPU_UNITS_QUERY): New macro.
2990
2991 * config/ia64/ia64.c: Include `hashtab.h'.
2992 (ia64_first_cycle_multipass_dfa_lookahead_guard,
2993 ia64_dfa_new_cycle, final_emit_insn_group_barriers,
2994 ia64_dfa_sched_reorder, get_free_bundle_state, free_bundle_state,
2995 initiate_bundle_states, finish_bundle_states, bundle_state_hash,
2996 bundle_state_eq_p, insert_bundle_state,
2997 initiate_bundle_state_table, finish_bundle_state_table,
2998 try_issue_nops, try_issue_insn, issue_nops_and_insn, get_max_pos,
2999 get_template, get_next_important_insn, bundling): New functions.
3000 (ia64_internal_sched_reorder): Remove it.
3001 (TARGET_SCHED_FIRST_CYCLE_MULTIPASS_DFA_LOOKAHEAD_GUARD,
3002 TARGET_SCHED_DFA_NEW_CYCLE): New macros.
3003 (ia64_safe_itanium_requires_unit0): Remove it.
3004 (group_barrier_needed_p): Place group barrier right before a real
3005 insn.
3006 (bundle, ia64_packet, NR_PACKETS, type_names, packets, packets):
3007 Remove them.
3008 (bundle_name): New variable.
3009 (_0mii_, _0mmi_, _0mfi_, _0mmf_, _0bbb_, _0mbb_, _0mib_, _0mmb_,
3010 _0mfb_, _0mlx_, _1mii_, _1mmi_, _1mfi_, _1mmf_, _1bbb_, _1mbb_,
3011 _1mib_, _1mmb_, _1mfb_, _1mlx_, pos_1, pos_2, pos_3, pos_4, pos_5,
3012 pos_6, dfa_stop_insn, last_scheduled_insn, dfa_state_size,
3013 temp_dfa_state, prev_cycle_state): New global variables.
3014 (insn_matches_slot, maybe_rotate, finish_last_head,
3015 rotate_one_bundle, rotate_one_bundles, nop_cycles_until,
3016 cycle_end_fill_slots, packet_matches_p, get_split, find_best_insn,
3017 find_best_packet, itanium_reorder, dump_current_packet,
3018 schedule_stop, gen_nop_type, ia64_emit_nops): Remove them.
3019 (sched_data, sched_ready, sched_types): Remove them.
3020 (ia64_sched_init): Initiate only `last_scheduled_insn' and call
3021 `init_insn_group_barriers'.
3022 (ia64_sched_reorder, ia64_sched_reorder2): Call
3023 ia64_dfa_sched_reorder.
3024 (ia64_variable_issue): Rewrite it.
3025 (bundle_state): New structure.
3026 (index_to_bundle_states, bundle_states_num,
3027 allocated_bundle_states_chain, free_bundle_state_chain): New
3028 global variables.
3029 (ia64_sched_finish): Add stop bits and call `bundling' after the
3030 2nd insn scheduling.
3031 (ia64_use_dfa_pipeline_interface): Return zero always.
3032 (ia64_first_cycle_multipass_dfa_lookahead): Return 6 for the 2nd
3033 insn scheduling.
3034 (ia64_init_dfa_pre_cycle_insn): Initialize `dfa_state_size',
3035 `temp_dfa_state', `prev_cycle_state', and `dfa_stop_insn'.
3036 (ia64_reorg): Add bundling insns.
3037
3038 * doc/tm.texi
3039 (TARGET_SCHED_FIRST_CYCLE_MULTIPASS_DFA_LOOKAHEAD_GUARD,
3040 TARGET_SCHED_DFA_NEW_CYCLE): Describe the new hooks.
07488f32 3041
30028c85
VM
3042 2002-09-23 Vladimir Makarov <vmakarov@redhat.com>
3043
3044 * config/ia64/ia64.md: Add Itanium1 DFA description.
3045 (itanium_class): Add `nop' and `pre_cycle'. Add
3046 define_function_unit for `nop'.
3047 (nop): Change attribute `itanium_class'.
3048 (pre_cycle): New define_insn.
3049
3050 * config/ia64/ia64-protos.h (bundling_p): New external variable.
3051 (ia64_st_address_bypass_p, ia64_ld_address_bypass_p,
3052 ia64_produce_address_p): New function prototypes.
3053
3054 * config/ia64/ia64.c (bundling_p): New global variable.
3055 (ia64_use_dfa_pipeline_interface,
3056 ia64_first_cycle_multipass_dfa_lookahead,
3057 ia64_init_dfa_pre_cycle_insn, ia64_dfa_pre_cycle_insn): New
3058 functions.
3059 (TARGET_SCHED_USE_DFA_PIPELINE_INTERFACE,
3060 TARGET_SCHED_FIRST_CYCLE_MULTIPASS_DFA_LOOKAHEAD,
3061 TARGET_SCHED_INIT_DFA_PRE_CYCLE_INSN,
3062 TARGET_SCHED_DFA_PRE_CYCLE_INSN): New macros.
3063 (ia64_sched_init, ia64_sched_reorder, ia64_sched_reorder2,
3064 ia64_variable_issue, ia64_sched_finish): Do nothing before reload.
3065 (dfa_pre_cycle_insn): New variable.
07488f32 3066
30028c85
VM
3067 2002-09-20 Vladimir Makarov <vmakarov@redhat.com>
3068
3069 * rtl.def (FINAL_PRESENCE_SET, FINAL_ABSENCE_SET): New
3070 constructions.
3071
3072 * genattrtab.h (gen_final_presence_set, gen_final_absence_set):
3073 New function prototypes.
3074
3075 * genattrtab.c (main): Process the new constructions.
3076
3077 * genautomata.c (gen_presence_absence_set,
3078 process_presence_absence_names, process_presence_absence_patterns,
3079 add_presence_absence, check_absence_pattern_sets): Add parameter
3080 `final_p'.
3081 (unit_decl): Add new members `final_presence_list' and
3082 `final_absence_list'.
3083 (unit_pattern_rel_decl): Add new member `final_p'.
3084 (gen_final_presence_set, gen_final_absence_set): New functions.
3085 (process_decls): Use member `final_p'.
3086 (temp_reserv): New global variable.
3087 (reserv_sets_are_intersected): Add processing `final_presence_set'
3088 and `final_absence_set'.
3089 (initiate_states): Allocate `temp_reserv'.
3090 (unit_final_presence_set_table, unit_final_absence_set_table): New
3091 gloabal variables.
3092 (initiate_presence_absence_pattern_sets): Initiate them.
3093 (NDFA_to_DFA): Fix typo.
3094 (output_description): Output `final_presence_set' and
3095 `final_absence_set'.
3096
3097 * doc/md.texi (final_presence_set, final_absence_set): Describe
3098 them.
07488f32 3099
30028c85
VM
3100 2002-09-20 Vladimir Makarov <vmakarov@redhat.com>
3101
3102 * genautomata.c (transform_3): Process a missing case (nothing on
3103 unit place).
3104
3105 2002-09-20 Vladimir Makarov <vmakarov@redhat.com>
3106
3107 * rtl.def (DEFINE_QUERY_CPU_UNIT, AUTOMATA_OPTION): Change
3108 comments about queried units and the minimization.
07488f32 3109
30028c85 3110 * doc/md.texi: Ditto.
07488f32 3111
30028c85
VM
3112 * genautomata.c (create_composed_state): Return nonzero if the new
3113 state has been created.
3114 (first_cycle_unit_presence): New function.
3115 (state_is_differed): Add new parameter. Use the new function.
3116 Take queried units into account.
3117 (partition_equiv_class): Pass additional parameter to
3118 `state_is_differed'.
3119 (merge_states): Process composed states too.
3120 (build_automaton, create_automata, output_min_issue_delay_table,
3121 output_tables, output_statistics): Output more information.
3122 (output_reserved_units_table): Use function
3123 `first_cycle_unit_presence'.
3124 (output_tables): Output table of queried units even if the
3125 minimization is switched on.
3126 (write_automata): Output code for querying units even if the
3127 minimization is switched on.
07488f32 3128
30028c85
VM
3129 2002-09-19 Vladimir Makarov <vmakarov@redhat.com>
3130
3131 * rtl.def (PRESENCE_SET, ABSENCE_SET): Add comments about extended
3132 syntax of the constructions.
07488f32 3133
30028c85
VM
3134 * doc/md.texi (PRESENCE_SET, ABSENCE_SET): Add description of
3135 extended syntax of the constructions.
07488f32 3136
30028c85
VM
3137 * genautomata.c (unit_rel_decl): Rename it to
3138 `unit_pattern_rel_decl'.
3139 (pattern_set_el, pattern_reserv): New structures.
3140 (pattern_set_el_t, pattern_reserv_t): New types.
3141 (gen_presence_absence_set): New function.
3142 (process_presence_absence): Remove it.
3143 (process_presence_absence_names,
3144 process_presence_absence_patterns): New functions.
3145 (get_presence_absence_set): Remove it.
3146 (initiate_presence_absence_sets): Rename it on
3147 `initiate_presence_absence_pattern_sets'. Use new function
3148 `form_reserv_sets_list'.
3149 (form_reserv_sets_list, check_presence_pattern_sets,
3150 check_absence_pattern_sets, output_pattern_set_el_list): New
3151 functions.
3152 (unit_decl): Change types of members `presence_list' and
3153 `absence_list'.
3154 (unit_rel_decl): Rename member `names_num' to `all_names_num'.
3155 (decl): Change types of members `excl', `presence', and `absence'.
3156 (get_str_vect): Rename `par_flag' to `paren_p'. Add null element
3157 at the end of the vector.
3158 (gen_cpu_unit, gen_query_cpu_unit, gen_bypass, gen_excl_set,
3159 gen_automaton, gen_regexp_repeat, gen_regexp_allof,
3160 gen_regexp_oneof, gen_regexp_sequence): Use boolean values.
3161 (gen_presence_set, gen_absence_set): Use new function
3162 `gen_presence_absence_set'.
3163 (add_presence_absence): Process `pattern_list' instead of
3164 `source_list'.
3165 (process_decls): USe new functions
3166 `process_presence_absence_names' and
3167 `process_presence_absence_patterns'.
3168 (reserv_sets_are_intersected): Use new function
3169 `check_presence_pattern_sets'.
3170 (presence_set, absence_set): Remove them.
3171 (unit_presence_set_table, unit_absence_set_table): New global
3172 variables.
3173 (output_description): Use new function
3174 `output_pattern_set_el_list'.
3175 (generate): Use `initiate_presence_absence_pattern_sets'.
07488f32 3176
30028c85
VM
3177 2002-09-18 Vladimir Makarov <vmakarov@redhat.com>
3178
3179 * genattr.c (main): Add output of prototype of new interface
3180 function `dfa_clean_insn_cache'.
3181
3182 * genautomata.c (output_dfa_clean_insn_cache_func): New function.
3183 (DFA_CLEAN_INSN_CACHE_FUNC_NAME): New macro.
3184 (output_dfa_start_func): Use function `dfa_clean_insn_cache' in
3185 the generated code.
3186 (write_automata): Call the new function.
07488f32 3187
cb297538
JH
3188Thu Jan 9 22:47:38 CET 2003 Jan Hubicka <jh@suse.cz>
3189
17211ab5
GK
3190 * i386.md (unit, prefix_0f, memory attributes): Hanlde sseicvt
3191 correctly.
cb297538 3192
3a6e2189
PC
31932003-01-09 Paolo Carlini <pcarlini@unitus.it>
3194
3195 * doc/tm.texi (EXTRA_ADDRESS_CONSTRAINT): Fix typo.
3196
97488870
R
3197Thu Jan 9 17:26:40 2003 J"orn Rennecke <joern.rennecke@superh.com>
3198
3199 * defaults.h (EXTRA_MEMORY_CONSTRAINT): Add STR argument.
3200 (EXTRA_ADDRESS_CONSTRAINT): Likewise.
3201 (CONSTRAINT_LEN): Provide default definition.
3202 (CONST_OK_FOR_CONSTRAINT_P): Likewise.
3203 (CONST_DOUBLE_OK_FOR_CONSTRAINT_P): Likewise.
3204 (EXTRA_CONSTRAINT_STR): Likewise.
3205 (REG_CLASS_FROM_CONSTRAINT): Define.
3206 * genoutput.c (check_constraint_len, constraint_len): New functions.
3207 (validate_insn_alternatives): Check CONSTRAINT_LEN for each
3208 constraint / modifier.
3209 (gen_insn): Call check_constraint_len.
3210 * local-alloc.c (block_alloc): Update to use new macros / pass
3211 second argument to EXTRA_{MEMORY,ADDRESS}_CONSTRAINT.
3212 * ra-build.c (handle_asm_insn): Likewise.
3213 * recog.c (asm_operand_ok, preprocess_constraints): Likewise.
3214 (constrain_operands, peep2_find_free_register): Likewise.
3215 * regclass.c (record_operand_costs, record_reg_classes): Likewise.
3216 * regmove.c (find_matches): Likewise.
3217 * reload.c (push_secondary_reload, find_reloads): Likewise.
3218 (alternative_allows_memconst): Likewise.
3219 * reload1.c (maybe_fix_stack_asms): Likewise.
3220 (reload_cse_simplify_operands): Likewise.
3221 * stmt.c (parse_output_constraint, parse_input_constraint): Likewise.
3222 * doc/tm.texi (CONSTRAINT_LEN, REG_CLASS_FROM_CONSTRAINT): Document.
3223 (CONST_OK_FOR_CONSTRAINT_P): Likewise.
3224 (CONST_DOUBLE_OK_FOR_CONSTRAINT_P, EXTRA_CONSTRAINT_STR): Likewise.
3225 (EXTRA_MEMORY_CONSTRAINT, EXTRA_ADDRESS_CONSTRAINT): Add STR argument.
3226 * config/s390/s390.h (EXTRA_MEMORY_CONSTRAINT): Likewise.
e2c734c1
R
3227
3228 * sh.h (OVERRIDE_OPTIONS): Allow first scheduling pass for SH5.
3229
fc182093
KH
32302003-01-09 Kazu Hirata <kazu@cs.umass.edu>
3231
3232 * config/h8300/h8300.md (*extzv_1_r_h8300): Correct the insn
3233 length.
3234 (*extzv_1_r_h8300hs): Likewise.
3235 (*extzv_1_r_inv_h8300): Likewise.
3236 (*extzv_1_r_inv_h8300hs): Likewise.
3237
3b1c9927
KH
32382003-01-09 Kazu Hirata <kazu@cs.umass.edu>
3239
3240 * config/h8300/h8300.h (PREDICATE_CODES): New.
3241
867504e6
KH
32422003-01-09 Kazu Hirata <kazu@cs.umass.edu>
3243
3244 * config/h8300/h8300.md (*addsi3_upper): New.
3245 (*iorsi3_shift): Likewise.
3246 (two splitters): Likewise.
3247 (*addsi3_shift): Likewise.
3248 (two splitters): Likewise.
3249
4a69cf79
JZ
32502003-01-09 Josef Zlomek <zlomj9am@artax.karlin.mff.cuni.cz>
3251
3252 * Makefile.in (optabs.o): Add dependency on basic-block.h.
3253 * basic-block.h (control_flow_insn_p): Fuction was exported.
3254 * cfgbuild.c (control_flow_insn_p): Fuction was made non-static.
3255 * optabs.c (emit_libcall_block): Emit REG_LIBCALL and REG_RETVAL
3256 notes only when the region is contained in a single basic block.
3257
4c46ea23
EB
32582003-01-09 Eric Botcazou <ebotcazou@libertysurf.fr>
3259
3260 PR inline-asm/8832
3261 * tree.h (expand_asm): New prototype.
3262 * stmt.c (expand_asm): Set the MEM_VOLATILE_P flag if instructed
3263 to do so.
3264 * c-semantics (genrtl_asm_stmt): Pass the RID_VOLATILE qualifier
3265 down to expand_asm.
3266 * c-typeck.c (simple_asm_stmt): Set the RID_VOLATILE qualifier.
3267 * rtlanal.c (volatile_insn_p) [ASM_INPUT]: Test the MEM_VOLATILE_P flag.
3268 (volatile_refs_p) [ASM_INPUT]: Likewise.
3269 (side_effects_p) [ASM_INPUT]: Likewise.
3270
f56e86bd
JH
3271Thu Jan 9 12:00:36 CET 2003 Jan Hubicka <jh@suse.cz>
3272
3273 * i386.md (*mul*): FIx constraints; remove confused comment; fix
3274 athlon_decode attributes
3275 (imul/k8 optimization peep2s): New.
3276
3277 * athlon.md (athlon_ssecmp*): Handle ssecomi as well.
3278 * i386.md (type attribute): Add ssecomi.
3279 (unit, memory, prefix attributes): Handle ssecomi.
3280 (cvt?2? patterns): Fix athlon_decode attribute
3281 (comi patterns): Set attribute to ssecomi.
3282
3283 PR target/8343
3284 * m68k.md (umulsidi, mulsidi expanders): Use register operand.
3285
98c29f71
RS
32862003-01-09 Richard Sandiford <rsandifo@redhat.com>
3287
3288 * config/mips/mips.h (PREDICATE_CODES): Add ADDRESSOF for predicates
3289 that match register_operands.
3290 * config/mips/mips.c (reg_or_0_operand, true_reg_or_0_operand): Make
3291 register_operand the default case.
3292
bbb818c6
EB
32932003-01-09 Eric Botcazou <ebotcazou@libertysurf.fr>
3294
3295 PR c/8032
3296 * c-typeck.c (process_init_element) [RECORD_TYPE]: For
3297 an empty element, do not advance the pointer to unfilled
3298 fields if there are pending initializers.
3299
90961eff
AJ
33002003-01-09 Christian Cornelssen <ccorn@cs.tu-berlin.de>
3301
3302 * Makefile.in (ORDINARY_FLAGS_TO_PASS): Also pass DESTDIR.
3303 (install-gcc-tooldir, install-cpp, installdirs,
3304 install-common, install-driver, install-info, install-man,
3305 install-headers, install-include-dir, install-headers-tar,
3306 install-headers-cpio, install-headers-cp, install-mkheaders,
3307 install-collect2, uninstall): Prepend $(DESTDIR) to
3308 destination paths in all (un)installation commands.
3309 (install-driver): Rewrite $(LN) commands to support DESTDIR
3310 with "ln" as well as with "ln -s".
3311 (installdirs): Simply use mkinstalldirs.
3312 (install-libgcc, install-multilib): Also pass DESTDIR.
3313 * mklibgcc.in: Prepend $(DESTDIR) to $(libsubdir) in the
3314 installation destination variable ldir.
3315 * config/alpha/t-osf4, config/arm/t-netbsd,
3316 config/ia64/t-hpux, config/mips/t-iris5-6,
3317 config/pa/t-hpux-shlib, config/rs6000/t-aix43,
3318 config/rs6000/t-aix52, config/t-slibgcc-elf-ver,
3319 config/t-slibgcc-sld: Prepend $$(DESTDIR) to $$(slibdir)
3320 in the definition of SHLIB_INSTALL.
3321 * config/arc/t-arc (install-multilib-arc): Prepend $(DESTDIR) to
3322 $(libsubdir) in the installation commands.
3323
8b26829f
KK
33242003-01-08 Kaz Kojima <kkojima@gcc.gnu.org>
3325
3326 * config/sh/sh.h (CASE_VECTOR_MODE): Use SImode for a
3327 non-optimizing compile.
3328 (ASM_OUTPUT_ADDR_VEC_ELT): Use .long for a non-optimizing
3329 compile.
3330
fe77449a
DR
33312003-01-08 Douglas B Rupp <rupp@gnat.com>
3332
3333 * config/i386/i386.c (ix86_attribute_table): Add new attributes
3334 ms_struct and gcc_struct.
3335 (ix86_handle_struct_attribute): New function.
3336 (ix86_ms_bitfield_layout_p): Update to take new attributes
3337 into account.
3338 * doc/extend.texi: Document new attributes.
3339 * testsuite/gcc.dg/bf-ms-attrib.c: New test.
3340
98417968
DS
33412003-01-08 Danny Smith <dannysmith@users.sourceforge.net>
3342
07488f32
ZW
3343 PR optimization/8750
3344 * config/i386/i386.c (ix86_expand_prologue): Don't allow
3345 scheduling pass to move insns across __alloca call.
98417968 3346
e46e3130
DJ
33472003-01-08 Dale Johannesen <dalej@apple.com>
3348
07488f32
ZW
3349 * config/rs6000/rs6000.md: Replace *store_multiple_string
3350 with *stmsi[3-8].
e46e3130 3351
c40e5172
JS
33522003-01-08 Jeff Sturm <jsturm@one-point.com>
3353
3354 PR target/9210
3355 * config/rs6000/rs6000.c (rs6000_elf_encode_section_info):
3356 Set SYMBOL_REF_FLAG on local data sym_ref.
3357
de62b72c 33582003-01-08 Dale Johannesen <dalej@apple.com>
07488f32
ZW
3359
3360 * function.c (assign_parms): Don't set pretend_args_size if
de62b72c 3361 REG_PARM_STACK_SPACE.
07488f32 3362 config/rs6000/rs6000.c (setup_incoming_varargs): Don't set
de62b72c
DJ
3363 pretend_args_size.
3364
25839c41
NN
33652003-01-08 Nathanael Nerode <neroden@gcc.gnu.org>
3366
3367 * gcc.hlp: Delete.
3368
4bdc8610
JH
3369Thu Jan 9 00:57:15 CET 2003 Jan Hubicka <jh@suse.cz>
3370
3371 * i386.c (ix86_expand_int_addcc): Fix thinko.
3372
5b71a4e7
DE
33732003-01-08 David Edelsohn <edelsohn@gnu.org>
3374
3375 * config/rs6000/rs6000.h (FUNCTION_MODE): Always use SImode.
3376 * config/rs6000/rs6000.c (TARGET_ASM_CAN_OUTPUT_MI_THUNK): Redefine
3377 as hook_bool_tree_hwi_hwi_tree_true.
3378 (rs6000_emit_allocate_stack): Use TARGET_32BIT.
3379 (rs6000_emit_epilogue): Same.
3380 (rs6000_output_mi_thunk): Re-implement as RTL.
3381 * config/rs6000/xcoff.h (ASM_DECLARE_FUNCTION_NAME): Call
3382 xcoffout_declare_function if any debugging enabled.
3383
2d2a50c3
CD
33842003-01-08 Chris Demetriou <cgd@broadcom.com>
3385
3386 * config.gcc (mipsisa32r2-*-elf*, mipsisa32r2el-*-elf*): New
3387 targets, to support MIPS32 Release 2 (MIPS32R2) configurations.
3388 * config/mips/mips.h (enum processor_type): Rename
3389 PROCESSOR_R4KC to PROCESSOR_4KC, PROCESSOR_R5KC to
3390 PROCESSOR_5KC, and PROCESSOR_R20KC to PROCESSOR_20KC.
3391 Add PROCESSOR_M4K.
3392 (TARGET_MIPS4KC, TARGET_MIPS5KC): Update for the renaming.
3393 (ISA_MIPS32R2): New define.
3394 (GENERATE_MULT3_SI, ISA_HAS_CONDMOVE, ISA_HAS_8CC)
3395 (ISA_HAS_MADD_MSUB, ISA_HAS_CLZ_CLO)
3396 (ISA_HAS_PREFETCH): Add support for MIPS32R2.
3397 (MIPS_ISA_DEFAULT): Likewise. Also, fix indentation.
3398 (TARGET_CPU_CPP_BUILTINS): Add support for MIPS32R2. Add new
3399 predefine __mips_isa_rev for MIPS32, MIPS32R2, and MIPS64.
3400 (ISA_HAS_ROTR_SI): Add support for MIPS32R2, and avoid if
3401 compiling MIPS16 code.
3402 (ISA_HAS_ROTR_DI): Do not use if compiling MIPS16 code, and fix
3403 comment.
3404 (ISA_HAS_SEB_SEH): New define.
3405 (ASM_SPEC, LINK_SPEC): Pass -mips32r2 to assembler and linker.
3406 * config/mips/mips.c (mips_cpu_info_table): Adjust for enum
3407 processor_type value renaming. Add support for MIPS32R2.
3408 Clean up comments, and move "sb1" entry with other MIPS64 CPU
3409 entries.
3410 (override_options): Reimplement -mipsN option handling so that
3411 it will work correctly for -mips32r2. Avoid branch-likely
3412 instructions on MIPS32R2.
3413 * config/mips/mips.md (mulsi3_mult3): Add support for MIPS32R2.
3414 (extendhisi2): Use extendhisi2_hw if ISA_HAS_SEB_SEH.
3415 (extendqisi2): Use extendqisi2_hw if ISA_HAS_SEB_SEH.
3416 (extendhisi2_hw, extendqisi2_hw): New.
3417 * config/mips/netbsd.h (TARGET_CPU_CPP_BUILTINS): Add support
3418 for MIPS32R2. Add new predefine __mips_isa_rev for MIPS32,
3419 MIPS32R2, and MIPS64.
3420 (LINK_SPEC): Pass -mips32r2 to linker.
3421 * config/mips/t-isa3264: Built -mips32r2 multilibs.
3422 * doc/invoke.texi (MIPS Options): Add -mips32r2, add support
3423 for mips32r2 in the -march description. Alphabetically sort
3424 CPU names in the -march description. Add long-missed -mips32
3425 and -mips64 to MIPS option summary.
3426
3427 * config.gcc: Update copyright years to include 2003.
3428 * config/mips/mips.c: Likewise.
3429 * config/mips/mips.h: Likewise.
3430 * config/mips/mips.md: Likewise.
3431 * config/mips/netbsd.h: Likewise.
3432 * doc/invoke.texi: Likewise.
3433
918c4fe4
AS
34342003-01-08 Andreas Schwab <schwab@suse.de>
3435
3436 * aclocal.m4 (gcc_AC_INITFINI_ARRAY): Fix spelling of cache
3437 variable.
3438 * configure: Regenerated.
3439
c5e7ce43
KH
34402003-01-08 Kazu Hirata <kazu@cs.umass.edu>
3441
3442 * config/h8300/h8300.c (output_logical_op): Replace byte/word
3443 extraction of det with b0, b1, w0, w2, etc.
3444 (compute_logical_op_length): Likewise.
3445 (compute_logical_op_cc): Likewise.
3446
eb8a8ec4
KH
34472003-01-08 Kazu Hirata <kazu@cs.umass.edu>
3448
3449 * config/h8300/h8300.h (CONSTANT_ADDRESS_P): Allow CONST and
3450 HIGH on all variants.
3451
56f15830 3452Wed Jan 8 14:06:34 CET 2003 Josef Zlomek <zlomj9am@artax.karlin.mff.cuni.cz>
07488f32 3453
56f15830
JZ
3454 * Makefile.in (PARTITION_H): New.
3455 (BASIC_BLOCK_H): Added hard-reg-set.h and $(PARTITION_H).
3456 * basic-block.h: Include hard-reg-set.h.
3457
ab57893b
RE
34582003-01-08 Richard Earnshaw <rearnsha@arm.com>
3459
3460 * arm.h (ENABLE_XF_PATTERNS): Delete.
3461 * arm.md (addxf3, subxf3, mulxf3, divxf3, modxf3, negxf2, absxf2)
3462 (sqrtxf2, floatsixf2, fix_truncxfsi2, truncxfsf2, truncxfdf2)
3463 (extendsfxf2, extenddfxf2, movxf, cmpxf, cmpxf_insn)
3464 (cmpxf_trap): Delete.
3465 (movxf_hard_insn): Remove test of ENABLE_XF_PATTERNS.
3466
7b52eede
JH
3467Wed Jan 8 12:10:57 CET 2003 Jan Hubicka <jh@suse.cz>
3468
3469 * i386.md (adddi3_carry_rex64, subdi3_carry_rex64): Name pattern.
3470 (addhi3_carry, addqi3_carry, subhi3_carry, subqi3_carry): New patterns.
3471 (add??cc): New expanders.
3472 * i386.c (expand_int_addcc): New function.
3473 * i386-protos.h (expand_int_addcc): Declare.
3474
3475 * alias.c (memory_modified_1): New static function.
3476 (memory_modified): New static varaible.
3477 (memory_modified_in_insn_p): New global function.
3478 * rtl.h (memory_modified_in_insn_p): Declare.
3479 * rtlanal.c (modified_between_p, modified_in_p): Be smart about memory
3480 references.
3481
3482 * expr.h (emit_conditional_add): Declare.
3483
74049755
JJ
34842003-01-07 Janis Johnson <janis187@us.ibm.com>
3485
3486 PR other/8947
3487 * doc/invoke.texi (-malign-double): Explain that the option breaks
3488 binary compatibility.
3489
e7edc5a0
AS
34902003-01-08 Andreas Schwab <schwab@suse.de>
3491
3492 * config.gcc (m68k-*-linux*): Don't set extra_parts and gnu_ld,
3493 should come from the generic *-*-linux* entry.
3494
9635cfad
JH
3495Tue Jan 7 22:29:56 CET 2003 Jan Hubicka <jh@suse.cz>
3496
3497 * cselib.c (cselib_current_insn_in_libcall): New static variable.
3498 (new_elt_loc_list, cselib_process_insn, cselib_init): Keep track on whether
3499 we are inside libcall.
3500 * cselib.h (elt_loc_list): Add in_libcall.
3501 * gcse.c (do_local_cprop): Do not copy propagate using insns
3502 in libcalls.
3503
3ee04299
DE
35042003-01-07 David Edelsohn <edelsohn@gnu.org>
3505
3506 * doc/tm.texi (TARGET_SCHED_VARIABLE_ISSUE): CLOBBER and USE do
3507 not normally affect to issue rate.
3508
068f5dea
JH
3509Tue Jan 7 21:46:57 CET 2003 Jan Hubicka <jh@suse.cz>
3510
3511 * genopinit.c (optabs): Add addc_optab.
3512 * ifcvt.c (noce_try_store_flag): Rename to ...
3513 (noce_try_addcc): ... this one; handle generic conditional increment.
3514 (noce_process_if_block): Update noce_try_addcc call.
3515 * optabs.c (emit_conditional_add): New.
3516 (init_obtabs): Initialize addc_optab.
3517 * optabs.h (optab_index): Add OTI_addcc.
3518 (addcc_optab): New macro.
3519 * md.texi: Document addMcc
3520
3521 PR target/8322
3522 * i386.c (ix86_init_mmx_sse_builtins): Constify arguments of loads.
3523 * xmmintrin.h (_mm_load*_si128. _mm_store*_si128): Add casts.
3524 * xmmintrin.h (_mm_load*_si128. _mm_store*_si128): Add casts.
3525
3526 * reload1.c (delete_output_reload): Avoid repeated attempts
3527 to delete insn.
3528
eb70d86d
AS
35292003-01-07 Andreas Schwab <schwab@suse.de>
3530
e7edc5a0
AS
3531 * configure.in: Restore CFLAGS before gcc_AC_INITFINI_ARRAY.
3532 Move --enable-initfini-array check ...
3533 * aclocal.m4 (gcc_AC_INITFINI_ARRAY): ... here. Define
3534 HAVE_INITFINI_ARRAY also when --enable-initfini-array is given.
3535 Don't AC_SUBST gcc_cv_initfinit_array. Use AC_TRY_RUN.
3536 * configure: Rebuild.
eb70d86d 3537
1afdf91c
RH
35382003-01-07 Richard Henderson <rth@redhat.com>
3539
e7edc5a0
AS
3540 * alias.c (find_base_value): Only use new_reg_base_value shortcut
3541 if the register is set once.
1afdf91c 3542
36210500 35432003-01-07 Sylvain Pion <Sylvain.Pion@mpi-sb.mpg.de>
07488f32 3544
36210500
SP
3545 * config/i386/i386.c (ix86_init_mmx_sse_builtins):
3546 __builtin_ia32_ldmxcsr and __builtin_ia32_stmxcsr are SSE, not MXX.
3547 * config/i386/i386.md (ldmxcsr, stmxcsr): SSE, not MMX.
3548
cb25b0ce
BK
35492003-01-07 Benjamin Kosnik <bkoz@redhat.com>
3550 Sunil Davasam <sunil.k.davasam@intel.com>
3551
07488f32 3552 PR libstdc++/9076
cb25b0ce
BK
3553 * unwind-dw2.c (execute_cfa_program): DW_CFA_undefined,
3554 DW_CFA_same_value, read next and ignore.
3555
94c040bd
RH
35562003-01-07 Richard Henderson <rth@redhat.com>
3557
3558 * cfganal.c (flow_call_edges_add): Don't crash on noreturn call.
3559
f6cb56fa
DB
35602003-01-07 Daniel Berlin <dberlin@dberlin.org>
3561
3562 * cfg.c: Include alloc-pool.h
3563 (edge_pool): New pool.
3564 (bb_pool): New pool.
3565 (first_deleted_edge): Remove.
3566 (first_deleted_block): Remove.
3567 (init_flow): Alloc/free the pools.
3568 (free_edge): Use pools.
3569 (alloc_block): Ditto.
3570 (expunge_block): Ditto.
3571 (cached_make_edge): Ditto.
3572
3573 * Makefile.in (cfg.o): Add alloc-pool.h dependency.
3574
35752003-01-07 Daniel Berlin <dberlin@dberlin.org>
3576
3577 * et-forest.c: Include alloc-pool.h.
3578 (struct et_forest): Add node_pool and occur_pool.
3579 (et_forest_create): Create the new pools.
3580 (et_forest_delete): Delete them.
3581 (et_forest_add_node): Allocate and free using pools.
3582 (et_forest_add_edge): Ditto.
3583 (et_forest_remove_node): Ditto.
3584 (et_forest_remove_edge): Ditto.
3585
3586 * Makefile.in (et-forest.o): Add alloc-pool.h dependency.
3587
f9ac2f95
KH
35882003-01-07 Kazu Hirata <kazu@cs.umass.edu>
3589
3590 * config/h8300/h8300.c (output_logical_op): Simplify and
3591 optimize the handling of SImode.
3592 * config/h8300/h8300.c (compute_logical_op_length): Update
3593 accordingly.
3594 * config/h8300/h8300.c (compute_logical_op_cc): Likewise.
3595
83282119
RS
35962003-01-07 Richard Sandiford <rsandifo@redhat.com>
3597
3598 * config/mips/mips.c (mips_va_arg): In the EABI code, apply the
3599 big-endian correction to indirect arguments too.
3600
59a4c851
AH
36012003-01-06 Aldy Hernandez <aldyh@redhat.com>
3602
3603 Segher Boessenkool <segher@koffie.nl>
3604
36210500
SP
3605 * config/rs6000/rs6000.c (rs6000_reg_names): Add missing registers.
3606 (alt_reg_names): Ditto, fix formatting.
3607 * config/rs6000/rs6000.h (DEBUG_REGISTER_NAMES): Fix formatting.
59a4c851 3608
7798db98
KH
36092003-01-06 Kazu Hirata <kazu@cs.umass.edu>
3610
3611 * config/h8300/h8300.c (final_prescan_insn): Constify uid.
3612 (output_logical_op): Constify intval and det.
3613 (compute_logical_length): Likewise.
3614 (compute_logical_cc): Likewise.
3615 (output_a_shift): Constify mask.
3616 (h8300_encode_label): Constify len.
3617
4705d102
KH
36182003-01-06 Kazu Hirata <kazu@cs.umass.edu>
3619
3620 * config/h8300/h8300.c (h8300_expand_prologue): Remove fsize.
3621 (h8300_expand_epilogue): Likewise.
3622
98c9a8e8
AH
36232003-01-06 Aldy Hernandez <aldyh@redhat.com>
3624
3625 Segher Boessenkool <segher@koffie.nl>
3626
36210500
SP
3627 * config/rs6000/altivec.md: Remove spaces from assembler
3628 instruction argument lists.
07488f32 3629
86143814
MH
36302003-01-07 Michael Hayes <m.hayes@elec.canterbury.ac.nz>
3631
3632 * config/c4x/c4x.c (c4x_naked_function_p): Rename from
3633 c4x_assembler_function_p.
3634 (c4x_null_epilogue_p): Complement return value, all uses updated.
3635 (c4x_insert_attributes): Add naked.
3636 * config/c4x/c4x.md (c4x_null_epilogue_p): Changes uses.
3637 * doc/extend.texi: Update C4x function attributes.
3638
52fd80fb
RH
36392003-01-06 Richard Henderson <rth@redhat.com>
3640
3641 * config/alpha/alpha.c (alpha_encode_section_info): Adjust symbol_str
3642 properly when changing "local-ness".
3643 * config/alpha/alpha.md (movdi_er_high_g): Allow all symbols.
3644
a16b43c5
DJ
36452003-01-06 Dale Johannesen <dalej@apple.com>
3646
3647 * config/darwin-protos.h: Add prototypes for new section functions.
3648
ef8dfae6
CD
36492003-01-06 Chris Demetriou <cgd@broadcom.com>
3650
3651 * config.gcc (mipsisa32-*-elf*, mipsisa32el-*-elf*): Default ABI
3652 to EABI.
3653
44f9a8e4
ZW
36542003-01-06 Zack Weinberg <zack@codesourcery.com>
3655
3656 * hwint.h: If the current compiler has no 64-bit type at all,
3657 make HOST_WIDEST_INT 32 bits.
3658
2610198a
EC
36592003-01-06 Eric Christopher <echristo@redhat.com>
3660
3661 * config/mips/mips.md (movdf_internal2): Fix constraints.
3662
efbd757f
KH
36632003-01-06 Kazu Hirata <kazu@cs.umass.edu>
3664
3665 * config/h8300/h8300.md (*twoshifts_l16_r1): New.
3666
727b9b8c
RS
36672003-01-06 Richard Sandiford <rsandifo@redhat.com>
3668
3669 * config/mips/mips.md (leadi): Use dla rather than la.
3670
4705d102 36712003-01-06 Svein E. Seldal <Svein.Seldal@solidas.com>
cebdac46
SS
3672
3673 * config/c4x/c4x.h: Updated specs for new gas format. Fixed bug
3674 in C33_FLAG. Added proper C33 support in ASM_FILE_START macro.
3675
4705d102 36762003-01-06 Herman A.J. ten Brugge <hermantenbrugge@home.nl>
fe1e789f 3677
44f9a8e4 3678 * config/c4x/c4x.h: Remove hwint.h include and HOST_WIDE_INT_PRINT_HEX
fe1e789f
HB
3679 redefinition.
3680
dff0ea43
KH
36812003-01-05 Kazu Hirata <kazu@cs.umass.edu>
3682
3683 * config/h8300/h8300.md (*extzv_8_23): New.
3684
94e6fd3e
JDA
36852003-01-05 John David Anglin <dave@hiauly1.hia.nrc.ca>
3686
3687 * pa64-hpux.h (JCR_SECTION_NAME): Define.
3688 (PA_INIT_FRAME_DUMMY_ASM_OP): Check EH_FRAME_SECTION_NAME instead of
3689 USE_EH_FRAME_REGISTRY when defining.
3690
cd9b5ca8
KH
36912003-01-05 Kazu Hirata <kazu@cs.umass.edu>
3692
3693 * config/h8300/h8300.c (output_a_shift): Do not output a
3694 variable shift.
3695 * config/h8300/h8300.md (two splitters): New.
3696
1ba8a9c4
RS
36972003-01-05 Richard Sandiford <rsandifo@redhat.com>
3698
3699 * config/mips/mips.md: Disable the movstrsi define_split.
3700
c7c50494
KG
37012003-01-05 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
3702
3703 * alloc-pool.c: Don't include "libiberty.h".
3704 * config/sparc/gmon-sol2.c: Include <fcntl.h>.
3705 * convert.c (convert_to_real): Hide unused variable.
3706
83fa8d7a
KG
37072003-01-04 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
3708
3709 * Makefile.in (gtyp-gen.h): Const-ify.
3710 * gcov-dump.c (tag_table): Likewise.
3711
871dab3e
BK
37122003-01-04 Bruce Korb <bkorb@gnu.org>
3713
3714 * fixinc/fixfixes.c(wrap_fix): the wrapper guard must be a function
3715 of *both* the file name and the fix name.
3716
90961eff 37172003-01-04 John David Anglin <dave.anglin@nrc.ca>
35d434ed
JDA
3718
3719 * config.gcc (hppa*64*-*-hpux11*): Define extra_parts. Don't use
3720 collect2.
3721 * pa-hpux11.h (LDD_SUFFIX, PARSE_LDD_OUTPUT): Undefine.
3722 (HAS_INIT_SECTION, LD_INIT_SWITCH, LD_FINI_SWITCH): Define.
3723 * pa64-hpux.h (HP_INIT_ARRAY_SECTION_ASM_OP,
3724 GNU_INIT_ARRAY_SECTION_ASM_OP, HP_FINI_ARRAY_SECTION_ASM_OP,
3725 GNU_FINI_ARRAY_SECTION_ASM_OP): Define.
3726 (CTORS_SECTION_ASM_OP, DTORS_SECTION_ASM_OP): Define when not using
3727 elfos.h.
3728 (EH_FRAME_IN_DATA_SECTION): Delete define.
3729 (HAS_INIT_SECTION, LD_INIT_SWITCH, LD_FINI_SWITCH): Undefine.
3730 (STARTFILE_SPEC): Use crtbegin.o.
3731 (ENDFILE_SPEC): Use crtend.o.
3732 (INIT_SECTION_ASM_OP, FINI_SECTION_ASM_OP, CRT_CALL_STATIC_FUNCTION,
3733 SUPPORTS_INIT_PRIORITY, PA_CXA_FINALIZE_STUB, PA_INIT_FINI_HACK,
3734 PA_INIT_FRAME_DUMMY_ASM_OP, PA_JV_REGISTERCLASSES_STUB,
3735 DTOR_LIST_BEGIN): Define.
3736 * pa.c (TARGET_ASM_CONSTRUCTOR): Define.
3737 (pa_asm_out_constructor, pa_asm_out_destructor): New functions.
3738 * som.h (SUPPORTS_INIT_PRIORITY): Delete define.
3739
b0588013
BK
37402002-12-31 Larin Hennessy <larin@science.oregonstate.edu>
3741
3742 * fixinc/fixinc.svr4: Remove references to i860, Sony NewsOS, and spur.
3743 * fixinc/inclhack.def: Remove tests for Apple A/UX, ARM/RISCiX, DG/UX,
3744 m88k-*-sysv3*, Sony NewsOS. Remove references to i860.
3745 Cleanup handling of replacement text.
3746 * fixinc/mkfixinc.sh: Remove reference to i?86-*-osf1*
3747
37482003-01-04 Bruce Korb <bkorb@gnu.org>
3749
3750 * fixinc/tests/base/math.h: removed obsolete results
3751 * fixinc/tests/base/stdlib.h: ditto
3752 * fixinc/tests/base/sys/param.h: ditto
3753 * fixinc/tests/base/sys/stat.h: ditto
3754 * fixinc/tests/base/time.h: ditto
3755 * fixinc/tests/base/X11/Intrinsic.h: removed obsolete file
3756 * fixinc/tests/base/sys/byteorder.h: ditto
3757 * fixinc/inclhack.def: Remove superfluous backslashes
3758
68ee6df6
KH
37592003-01-04 Kazu Hirata <kazu@cs.umass.edu>
3760
3761 * config/h8300/h8300-protos.h: Add prototypes for
3762 the new functions defined below.
3763 * config/h8300/h8300.c (TARGET_ASM_FUNCTION_PROLOGUE): Do not
3764 define.
3765 (dosize): Emit RTL instead of assembly code.
3766 (push): Likewise.
3767 (pop): Likewise.
3768 (h8300_output_function_prologue): Remove.
3769 (h8300_expand_prologue): New.
3770 (h8300_expand_epilogue): New.
3771 (h8300_output_function_epilogue): Do only the reset of
3772 pragma_saveall.
3773 * config/h8300/h8300.md (push_h8300): New.
3774 (push_h8300hs): Likewise.
3775 (pop_h8300): Likewise.
3776 (pop_h8300hs): Likewise.
3777 (*stm_h8300s_2): Change the name to stm_h8300s_2.
3778 (*stm_h8300s_3): Change the name to stm_h8300s_3.
3779 (*stm_h8300s_4): Change the name to stm_h8300s_4.
3780 (*ldm_h8300s_2): New.
3781 (*ldm_h8300s_3): Likewise.
3782 (*ldm_h8300s_4): Likewise.
3783 (return): Likewise.
3784 (*return_1): Likewise.
3785 (prologue): Likewise.
3786 (epilogue): Likewise.
3787 (monitor_prologue): Likewise.
3788
d3c300d2
DJ
37892003-01-03 Dale Johannesen <dalej@apple.com>
3790
3791 * config/darwin.h: (EXTRA_SECTIONS): Add machopic_symbol_stub1,
3792 machopic_picsymbol_stub1.
3793 (EXTRA_SECTION_FUNCTIONS): Ditto.
3794 * rs6000/rs6000.c: Update copyright.
3795 (machopic_output_stub): Use them. Remove an insn from stub code.
3796
6cce57b0
JM
37972003-01-02 Jason Merrill <jason@redhat.com>
3798
4e8dca1c
JM
3799 * fold-const.c (fold) [COND_EXPR]: Avoid NOP_EXPRs better.
3800
3801 * integrate.c (copy_decl_for_inlining): Don't clear the rtl for
3802 static/external decls.
2610198a 3803
6cce57b0
JM
3804 * c-common.c (finish_fname_decls): Put the DECL_STMTs inside the
3805 outermost scope.
3806 * c-decl.c (c_make_fname_decl): Push the decls there, too.
3807
e392d367
KH
38082003-01-03 Kazu Hirata <kazu@cs.umass.edu>
3809
3810 * config/h8300/h8300-protos.h: Add a prototype for
3811 h8300_current_function_interrupt_function_p.
3812 * config/h8300/h8300.c (interrupt_handler): Remove.
3813 (os_task): Likewise.
3814 (monitor): Likewise.
3815 (pragma_interrupt): New.
3816 (WORD_REG_USED): Use
3817 h8300_current_function_interrupt_function_p.
3818 (dosize): Likewise.
3819 (h8300_output_function_prologue): Likewise.
3820 Do not set interrupt_handler, os_task, monitor.
3821 (h8300_output_function_prologue): Use
3822 h8300_current_function_interrupt_function_p.
3823 Do not set interrupt_handler, os_task, monitor.
3824 (h8300_current_function_interrupt_function_p): New.
3825 (h8300_pr_interrupt): Set pragma_interrupt.
3826 (h8300_insert_attributes): Reset pragma_interrupt.
3827
b15da5b7
GP
38282003-01-03 Gerald Pfeifer <pfeifer@dbai.tuwien.ac.at>
3829
3830 * doc/install.texi (Configuration): Fix markup for reference to
3831 gcc/config.gcc.
3832
bf16e745
KH
38332003-01-02 Kazu Hirata <kazu@cs.umass.edu>
3834
3835 * config/h8300/h8300.md (*iorhi3_zext): Relax the condition.
3836 (*iorhi3_two_qi): Likewise.
3837 (*iorsi3_zexthi): Likewise.
3838 (*xorhi3_zextqi): Likewise.
3839 (*xorsi3_zexthi): Likewise.
3840 (*xorsi3_zextqi): Likewise.
3841
8ccf5d5f
KH
38422003-01-02 Kazu Hirata <kazu@cs.umass.edu>
3843
3844 * config/h8300/h8300.c (stack_pointer_operand): New.
3845 (const_int_gt_2_operand): Likewise.
3846 (const_int_ge_8_operand): Likewise.
3847 * config/h8300/h8300.md (a splitter): Likewise.
3848 (a peephole2): Likewise.
3849 * config/h8300/h8300-protos.h: Add prototypes for the new
3850 functions above.
3851
43c6a96a
SB
38522003-01-02 Steven Bosscher <s.bosscher@student.tudelft.nl>
3853
3854 * objc/Make-lang.in, objc/config-lang.in, objc/lang-specs.h,
3855 objc/objc-act.h: Fix copyright years.
3856
96c4e780
SB
38572003-01-02 Steven Bosscher <s.bosscher@student.tudelft.nl>
3858
3859 * doc/passes.texi: Fix documentation for -fssa-ccp
3860
8ed0a104
NB
38612003-01-02 Neil Booth <neil@daikokuya.co.uk>
3862
3863 * gccbug.in: Update for new categories.
3864
1b9f0361
KH
38652003-01-01 Kazu Hirata <kazu@cs.umass.edu>
3866
3867 * config/h8300/h8300.md: Reorder some patterns.
3868
dc5f17ec
KH
38692003-01-01 Kazu Hirata <kazu@cs.umass.edu>
3870
3871 * config/h8300/h8300.c (output_logical_op): Fix a warning.
3872
cd2801fb
NB
38732003-01-01 Neil Booth <neil@daikokuya.co.uk>
3874
3875 * config/darwin-protos.h, config/c4x/c4x-protos.h,
3876 config/cris/cris-protos.h, config/i370/i370-protos.h,
3877 config/i960/i960-protos.h, config/ia64/ia64-protos.h,
3878 config/v850/v850-protos.h: Use struct, and don't conditionally
3879 compile on GCC_C_PRAGMA_H.
3880
378b1b8e
KH
38812003-01-01 Kazu Hirata <kazu@cs.umass.edu>
3882
3883 * config/arm/arm-protos.h: Remove #ifdef GCC_C_PRAGMA_H.
3884 * config/h8300/h8300-protos.h: Likewise.
3885 * config/sh/sh-protos.h: Likewise.
3886
7106a5bc
KH
38872003-01-01 Kazu Hirata <kazu@cs.umass.edu>
3888
3889 * config/arm/arm-protos.h: Use struct cpp_reader instead of
3890 cpp_reader.
3891 * config/h8300/h8300-protos.h: Likewise.
3892 * config/sh/sh-protos.h: Likewise.
3893
231b51a1
NB
38942003-01-01 Neil Booth <neil@daikokuya.co.uk>
3895
3896 * config/arm/arm.c (arm_pr_long_calls, arm_pr_no_long_calls,
3897 arm_pr_long_calls_off): Use struct.
3898 * config/h8300/h8300.c (h8300_pr-interrupt, h8300_pr_saveall)
3899 : Similarly.
3900 Don't include cpplib.h.
3901 * config/sh/sh.c (sh_pr_interrupt, sh_pr_trapa,
3902 sh_pr_nosave_low_regs): Similarly.
3903
0f18b2b0
KH
39042003-01-01 Kazu Hirata <kazu@cs.umass.edu>
3905
3906 * config/h8300/h8300.c: Include cpplib.h.
3907
b9593599
SB
39082003-01-01 Steven Bosscher <s.bosscher@student.tudelft.nl>
3909
3910 * objc/Make-lang.in, objc/config-lang.in, objc/lang-options.h,
3911 objc/lang-specs.h, objc/objc-act.c, objc/objc-act.h,
3912 objc/objc-lang.c, objc/objc-tree.def: Replace "GNU CC" with
3913 "GCC" in the copyright header.
3914
c58b209a
NB
39152003-01-01 Neil Booth <neil@daikokuya.co.uk>
3916
3917 * c-pragma.c (c_register_pragma): New.
3918 (init_pragma): Use it.
3919 * c-pragma.h (cpp_register_pragma): Don't declare.
3920 (c_register_pragma): New.
3921 * cpplib.h: Remove #ifdef GCC_C_PRAGMA_H.
3922 * config/darwin.h (REGISTER_TARGET_PRAGMAS): Update.
3923 * config/arm/arm.h (REGISTER_TARGET_PRAGMAS): Update.
3924 * config/c4x/c4x.h (REGISTER_TARGET_PRAGMAS): Update.
3925 * config/h8300/h8300.h (REGISTER_TARGET_PRAGMAS): Update.
3926 * config/i370/i370.h (REGISTER_TARGET_PRAGMAS): Update.
3927 * config/i960/i960.h (REGISTER_TARGET_PRAGMAS): Update.
3928 * config/ia64/hpux.h (REGISTER_TARGET_PRAGMAS): Update.
3929 * config/rs6000/rs6000.h (REGISTER_TARGET_PRAGMAS): Update.
3930 * config/sh/sh.h (REGISTER_TARGET_PRAGMAS): Update.
3931 * config/v850/v850.h (REGISTER_TARGET_PRAGMAS): Update.
3932 * doc/tm.texi (REGISTER_TARGET_PRAGMAS): Update
3933
bc455f9c
KH
39342002-12-31 Kazu Hirata <kazu@cs.umass.edu>
3935
3936 * config/h8300/h8300-protos.h: Update the prototypes.
3937 * config/h8300/h8300.c (const_le_2_operand): Change to
3938 const_int_le_2_operand.
3939 (const_int_le_6_operand): Change to const_int_le_6_operand.
3940 * config/h8300/h8300.md (two peepholes): Update the function
3941 names.
3942
3b41afd9
TT
39432002-12-31 Tom Tromey <tromey@redhat.com>
3944
3945 * doc/install.texi (Testing): Fixed typo.
3946
9e56a932
KH
39472002-12-31 Kazu Hirata <kazu@cs.umass.edu>
3948
3949 * config/h8300/h8300.h (TRAMPOLINE_TEMPLATE): Remove.
3950 (TRAMPOLINE_SIZE): Support the normal mode.
3951 (INITIALIZE_TRAMPOLINE): Emit the entire trampoline.
3952
731e8b38
MM
39532002-12-31 Mark Mitchell <mark@codesourcery.com>
3954
3955 * c-common.h (pending_lang_change): Declare.
3956
147d1cd3
JQ
39572002-12-31 Jerry Quinn <jlquinn@optonline.net>
3958
3959 * gcc/doc/invoke.texi (Optimization Options): Clean up -O flag
3960 descriptions.
3961
fad893da
JQ
39622002-12-31 Jerry Quinn <jlquinn@optonline.net>
3963
3964 * gcc/doc/invoke.texi (Optimization Options): List the options
3965 enabled by each -O flag.
3966
ec5b5ef1
GP
39672002-12-31 Gerald Pfeifer <pfeifer@dbai.tuwien.ac.at>
3968
3969 * doc/install.texi (Configuration): Explicitly refer
3970 gcc/config.gcc for a list of cpu models.
3971
59d7c857
KH
39722002-12-31 Kazu Hirata <kazu@cs.umass.edu>
3973
3974 * config/h8300/h8300.h: Fix comment typos.
3975
5b8f5865
DE
39762002-12-30 David Edelsohn <edelsohn@gnu.org>
3977
3978 * config/rs6000/rs6000.h (WIDEST_HARDWARE_FP_SIZE): Define.
3979
582f6e6d
TT
39802002-12-30 Tom Tromey <tromey@redhat.com>
3981
3982 * doc/install.texi (Testing): Mention Jacks.
3983
f75db6bc
JM
39842002-12-30 Joseph S. Myers <jsm@polyomino.org.uk>
3985
3986 * doc/gcc.texi, doc/gccint.texi: Update last modification dates.
3987
2d75548f
KH
39882002-12-30 Kazu Hirata <kazu@cs.umass.edu>
3989
3990 * config/h8300/h8300.c (output_logical_op): Use extu.w in more
3991 cases.
3992 (compute_logical_op_length): Update to reflect the change in
3993 output_logical_op.
3994 (compute_logical_op_cc): Likewise.
3995
b351c1d9
JM
39962002-12-30 Joseph S. Myers <jsm@polyomino.org.uk>
3997
3998 * doc/service.texi: Uncomment and update FAQ link.
3999
47ab0cbb
AJ
40002002-12-30 Andreas Jaeger <aj@suse.de>
4001
4002 * unwind-dw2-fde.h (last_fde): Add unused attribute for obj.
4003
3cc3e1cd
KH
40042002-12-30 Kazu Hirata <kazu@cs.umass.edu>
4005
4006 * config/h8300/h8300.md (*addsi3_lshiftrt_16_zexthi): New.
4007
a6e8d113
KH
40082002-12-30 Kazu Hirata <kazu@cs.umass.edu>
4009
4010 * config/h8300/h8300.c (output_logical_op): Use extu.w if we
4011 are clearing the most significant byte.
4012 (compute_logical_op_length): Update to reflect the change in
4013 output_logical_op.
4014 (compute_logical_op_cc): Likewise.
4015
c85263d2
KH
40162002-12-29 Kazu Hirata <kazu@cs.umass.edu>
4017
4018 * config/h8300/h8300.md: Give internal names to anonymous
4019 insns.
4020
fbcb02cd
KH
40212002-12-29 Kazu Hirata <kazu@cs.umass.edu>
4022
4023 * config/h8300/h8300.md: Reorder some insns.
4024
2873836b
KH
40252002-12-29 Kazu Hirata <kazu@cs.umass.edu>
4026
4027 * config/h8300/h8300-protos.h: Add prototypes for
4028 const_int_qi_operand and const_int_hi_operand.
4029 * config/h8300/h8300.c (const_int_qi_operand): New.
4030 (const_int_hi_operand): Likewise.
4031 * config/h8300/h8300.md (three peepholes): New.
4032
bdefb2ab
JM
40332002-12-28 Joseph S. Myers <jsm@polyomino.org.uk>
4034
4035 * doc/cpp.texi, doc/gcc.texi, doc/gccint.texi, doc/install.texi:
4036 Use @copying.
4037
a38f87a9
JM
40382002-12-28 Joseph S. Myers <jsm@polyomino.org.uk>
4039
4040 * configure.in: Increase makeinfo version requirement to 4.[2-9].
4041 * configure: Regenerate.
4042 * doc/install.texi: Update Texinfo version requirement.
4043
c14bc6db
AJ
40442002-12-28 Andreas Jaeger <aj@suse.de>
4045
b9b21a05
AJ
4046 * config/i386/i386.c (x86_function_profiler): Mark labelno as
4047 possibly unused.
4048
c14bc6db
AJ
4049 * c-parse.in (yyprint): Use HOST_WIDE_INT_PRINT_DOUBLE_HEX for
4050 correct format.
4051
62fbd434
KH
40522002-12-27 Kazu Hirata <kazu@cs.umass.edu>
4053
4054 * config/h8300/h8300.md (*iorhi_shift_8): Change the name to
4055 *iorhi_ashift_8.
4056 (*iorhi_lshiftrt_8): New.
4057
27e3f16d
JM
40582002-12-27 Joseph S. Myers <jsm@polyomino.org.uk>
4059
4060 * doc/include/texinfo.tex: Update to version 2002-12-26.16.
4061
b09975de
GP
40622002-12-27 Gerald Pfeifer <pfeifer@dbai.tuwien.ac.at>
4063
4064 * doc/contrib.texi (Contributors): Add Abramo and Roberto Bagnara.
4065
f411c849
KH
40662002-12-26 Kazu Hirata <kazu@cs.umass.edu>
4067
4068 * config/h8300/h8300-protos.h: Fix comment typos.
4069 Update copyright.
4070 * config/h8300/h8300.c: Fix comment typos.
4071
b976d7a0
KH
40722002-12-26 Kazu Hirata <kazu@cs.umass.edu>
4073
4074 * config/h8300/h8300.h (IDENT_ASM_OP): End with a tab.
4075
d1f87653
KH
40762002-12-26 Kazu Hirata <kazu@cs.umass.edu>
4077
4078 * config/i386/athlon.md: Fix comment typos.
4079 * config/i386/crtdll.h: Likewise.
4080 * config/i386/djgpp.h: Likewise.
4081 * config/i386/i386-interix.h: Likewise.
4082 * config/i386/i386.c: Likewise.
4083 * config/i386/i386.h: Likewise.
4084 * config/i386/i386.md: Likewise.
4085 * config/i386/k6.md: Likewise.
4086 * config/i386/mingw32.h: Likewise.
4087 * config/i386/pentium.md: Likewise.
4088 * config/i386/sco5.h: Likewise.
4089 * config/i386/winnt.c: Likewise.
4090 * config/i386/xmmintrin.h: Likewise.
4091
ecd4a73b
JR
40922002-12-26 Jose Renau <renau@cs.uiuc.edu>
4093
4094 * ssa-dce.c (EXECUTE_IF_UNNECESSARY): Verify INSN is an
4095 INSN_P before checking to see if it is dead.
4096 (mark_all_insn_unnecessary): Similarly.
4097 (ssa_eliminate_dead_code): Similarly.
4098 * rtl.h (struct rtx_def): Update comments for in_struct usage
4099 in dead code elimination pass.
4100 (INSN_DEAD_CODE_P): Allow JUMP_INSN and CALL_INSN as well.
4101
b17bb466
AS
41022002-12-26 Andreas Schwab <schwab@suse.de>
4103
c14bc6db 4104 * config.gcc (powerpc*-*-*, rs6000-*-*): Fix assignment syntax.
b17bb466 4105
b21fb038
DE
41062002-12-25 David Edelsohn <edelsohn@gnu.org>
4107
4108 * config/rs6000/rs6000.c (rs6000_override_options): Convert to
4109 tartet_flags_explicit.
4110 * config/rs6000/rs6000.h (MASK_MULTIPLE_SET, MASK_STRING_SET): Delete.
4111 Compact target_flags bits.
4112 (TARGET_MULTIPLE_SET, TARGET_STRING_SET): Delete.
4113 (TARGET_SWITCHES): Delete references to *_SET flags.
4114
abd2dd6d
JH
4115Wed Dec 25 20:30:53 CET 2002 Jan Hubicka <jh@suse.cz>
4116
4117 * i386.md (memory attribute): Fix setcc attribute.
4118
d55d8fc7
KH
41192002-12-25 Kazu Hirata <kazu@cs.umass.edu>
4120
4121 * output.h: Fix comment typos.
4122 * predict.c: Likewise.
4123 * print-tree.c: Likewise.
4124 * profile.c: Likewise.
4125 * ra-build.c: Likewise.
4126 * ra-colorize.c: Likewise.
4127 * ra-debug.c: Likewise.
4128 * ra-rewrite.c: Likewise.
4129 * ra.c: Likewise.
4130 * ra.h: Likewise.
4131 * real.c: Likewise.
4132 * recog.c: Likewise.
4133 * reg-stack.c: Likewise.
4134 * regclass.c: Likewise.
4135
7a770d8b
KH
41362002-12-25 Kazu Hirata <kazu@cs.umass.edu>
4137
4138 * config/h8300/h8300.c (print_operand_address): Do not negate
4139 a negative number when printing one.
4140
7d6ac401
KH
41412002-12-25 Kazu Hirata <kazu@cs.umass.edu>
4142
4143 * config/h8300/h8300-protos.h: Add prototypes for
4144 output_plussi, compute_plussi_length, and compute_plussi_cc.
4145 * config/h8300/h8300.c (output_plussi): New.
4146 (compute_plussi_length): Likewise.
4147 (compute_plussi_cc): Likewise.
4148 * config/h8300/h8300.md (addsi_h8300h): Call
4149 output_plussi, compute_plussi_length, and compute_plussi_cc.
4150
871d6a01
KH
41512002-12-24 Kazu Hirata <kazu@cs.umass.edu>
4152
4153 * config/h8300/h8300.md (two peepholes): Use match_dup instead
4154 of match_operand in the new patterns.
4155
4fbf9d4a
JM
41562002-12-24 Joseph S. Myers <jsm@polyomino.org.uk>
4157
4158 * doc/include/texinfo.tex: Update to version 2002-11-25.11.
4159
8601608f
NS
41602002-12-24 Nathan Sidwell <nathan@codesourcery.com>
4161
4162 * configure.in (enable-coverage): Add SELF_COVERAGE.
4163 * profile.c (end_branch_prob): Use SELF_COVERAGE.
4164
c28b4e40
JW
41652002-12-24 Jim Wilson <wilson@redhat.com>
4166
4167 * alias.c (record_set): Handle multi-reg hard registers.
4168
14b493d6
KH
41692002-12-24 Kazu Hirata <kazu@cs.umass.edu>
4170
4171 * regmove.c: Fix comment typos.
4172 * reload.c: Likewise.
4173 * reload1.c: Likewise.
4174 * resource.c: Likewise.
4175 * rtl.def: Likewise.
4176 * rtl.h: Likewise.
4177 * rtlanal.c: Likewise.
4178 * sched-deps.c: Likewise.
4179 * sched-rgn.c: Likewise.
4180 * sibcall.c: Likewise.
4181 * simplify-rtx.c: Likewise.
4182 * ssa-ccp.c: Likewise.
4183 * ssa.c: Likewise.
4184 * stmt.c: Likewise.
4185 * stor-layout.c: Likewise.
4186 * system.h: Likewise.
4187 * tlink.c: Likewise.
4188 * toplev.c: Likewise.
4189 * tracer.c: Likewise.
4190 * tree-inline.c: Likewise.
4191 * tree.c: Likewise.
4192 * tree.h: Likewise.
4193 * unroll.c: Likewise.
4194 * varasm.c: Likewise.
4195
c9693e96
LH
41962002-12-23 Larin Hennessy <larin@science.oregonstate.edu>
4197
4198 * doc/install.texi: Remove i386-*-isc, i860-*-bsd,
4199 m68k-altos-sysv, m68k-isi-bsd, m68k-sony-bsd entries.
4200 * doc/invoke.texi: Remove AMD 29K, ARM RISC/iX, Clipper, Convex,
4201 DG/UX entries.
4202 * doc/md.texi: Remove AMD 29K entries.
4203 * doc/trouble.texi: Remove Alliant, DG/UX, Iris 4.0.5F, GAS
4204 1.38.1, NewsOS, RT PC, WE32K entries.
4205
a67ed43f
AH
42062002-12-23 Aldy Hernandez <aldyh@redhat.com>
4207
44f9a8e4
ZW
4208 PR/8763
4209 * config/rs6000/altivec.md (mulv4sf3): Rewrite to add -0.0 vector.
4210 (altivec_vspltisw_v4sf): Name pattern.
4211 (altivec_vslw_v4sf): New pattern.
a67ed43f 4212
46d40353
JM
42132002-12-23 Joseph S. Myers <jsm@polyomino.org.uk>
4214
4215 * doc/include/gcc-common.texi: Define DEVELOPMENT.
4216
8dc65b6e
MM
42172002-12-23 Mark Mitchell <mark@codesourcery.com>
4218
4219 * stor-layout.c (update_alignment_for_field): Correct handling of
4220 unnamed bitfields on PCC_BITFIELD_TYPE_MATTERS machines.
4221 * doc/tm.texi (PCC_BITFIELD_TYPE_MATTERS): Note that an unnamed
4222 bitfield does not affect alignment.
4223
7c02ae17
DE
42242002-12-23 David Edelsohn <edelsohn@gnu.org>
4225
4226 * expr.c (expand_assignment): Apply special treatment to
4227 ARRAY_TYPE.
4228
317d21e9
KH
42292002-12-23 Kazu Hirata <kazu@cs.umass.edu>
4230
4231 * config/h8300/h8300-protos.h: Update the prototype of
4232 expand_a_shift.
4233 * config/h8300/h8300.c (expand_a_shift): Change the return
4234 type to void.
4235 * config/h8300/h8300.md: Update all the uses of
4236 expand_a_shift.
4237
0c685f12
NS
42382002-12-22 Nathan Sidwell <nathan@codesourcery.com>
4239
4240 * tree.c (save_expr): Allow either side of a dyadic operand to be
4241 constant.
4242
4243 * doc/portability.texi (portability): Update portability goals.
4244
ade53a50
KH
42452002-12-23 Kazu Hirata <kazu@cs.umass.edu>
4246
4247 * config/h8300/h8300.c (output_a_shift): Remove unused code.
4248
d0ff2db5
MM
42492002-12-22 Mark Mitchell <mark@codesourcery.com>
4250
d317855e
MM
4251 * stor-layout.c (update_alignment_for_field): Guard use of
4252 ADJUST_FIELD_ALIGN with #ifdef.
4253
d0ff2db5
MM
4254 * stor-layout.c (update_alignment_for_field): Use
4255 ADJUST_FIELD_ALIGN when computing the alignment for a zero-width
4256 bitfield when PCC_BITFIELD_TYPE_MATTERS.
4257
96e13905
KH
42582002-12-22 Kazu Hirata <kazu@cs.umass.edu>
4259
4260 * genautomata.c: Fix comment typos.
4261
66b4e478
JH
4262Sun Dec 22 18:23:44 CET 2002 Jan Hubicka <jh@suse.cz>
4263
4264 * params.def (tracer-min-branch-probability-feedback): Fix default.
4265 * final.c (compute_alignments): Use profile to avoid code bloat.
4266
a7612343
KH
42672002-12-22 Kazu Hirata <kazu@cs.umass.edu>
4268
4269 * config/h8300/h8300.c (get_shift_alg): Make shift insn
4270 sequences end with a valid cc0 whenever possible.
4271
8fb52ad1
KH
42722002-12-22 Kazu Hirata <kazu@cs.umass.edu>
4273
4274 * config/h8300/h8300.md (negsf2): New.
4275 (*negsf2_h8300): Likewise.
4276 (*negsf2_h8300hs): Likewise.
4277
2a77af27
GK
42782002-12-21 Geoffrey Keating <geoffk@apple.com>
4279
4280 * integrate.c (output_inline_function): Don't hold private
4281 pointers to 'struct function' over GC calls.
4282
5040eb00
KK
42832002-12-21 Kaz kojima <kkojima@gcc.gnu.org>
4284
4285 * config/sh/lib1funcs.asm (__fpscr_values): Conditionalize with
4286 NO_FPSCR_VALUES.
4287 * config/sh/t-linux (TARGET_LIBGCC2_CFLAGS): Add -DNO_FPSCR_VALUES.
4288
5d750136
KH
42892002-12-21 Kazu Hirata <kazu@cs.umass.edu>
4290
4291 * config/h8300/h8300.md (zero_extendqisi2): Correct the
4292 length.
4293
f7e42925
KH
42942002-12-21 Kazu Hirata <kazu@cs.umass.edu>
4295
4296 * config/h8300/h8300.md (*zero_extendqihi2_h8300): Make the
4297 second alternative "#".
4298 (*zero_extendqihi2_h8300hs): Likewise.
4299 (a define_split): New.
4300
3cee1a78
KH
43012002-12-21 Kazu Hirata <kazu@cs.umass.edu>
4302
4303 * config/h8300/h8300-protos.h: Update the prototype for
4304 split_adds_subs.
4305 Add prototypes for const_le_2_operand and const_le_6_operand.
4306 * config/h8300/h8300.c (split_adds_subs): Add an argument to
4307 specify whether inc/dec should be used when possible.
4308 (const_le_2_operand): New.
4309 (const_le_6_operand): Likewise.
4310 * config/h8300/h8300.md (two peepholes): New.
4311
40b982a9
KH
43122002-12-21 Kazu Hirata <kazu@cs.umass.edu>
4313
4314 * config/fr30/fr30.md: Fix a comment typo.
4315 * config/i386/i386.c: Likewise.
4316 * config/ip2k/ip2k.h: Likewise.
4317
60954572
JW
43182002-12-20 Jim Wilson <wilson@redhat.com>
4319
4320 * config/rs6000/spe.h (__ev_subifw): Reverse arguments.
4321 (__ev_subw, __ev_subiw): New.
4322 (ev_mwlssf, ev_mwlsmf, ev_mwlssfa, ev_mwlsmfa, ev_mwlssfaaw,
4323 ev_mwlsmfaaw, ev_mwlssfanw, ev_mwlsmfanw): Delete.
4324
11f43127
JDA
43252002-12-20 John David Anglin <dave.anglin@nrc.gc.ca>
4326
4327 * pa-linux.h (TARGET_HAS_STUBS_AND_ELF_SECTIONS): Delete define.
4328 * pa32-linux.h (FUNCTION_OK_FOR_SIBCALL): Delete define.
4329 * pa.c (pa_function_ok_for_sibcall): Allow non indirect sibcalls on
4330 TARGET_ELF32. Add comment on sibcall issues for TARGET_64BIT.
4331
f9d2de4d
KH
43322002-12-20 Kazu Hirata <kazu@cs.umass.edu>
4333
4334 * config/h8300/h8300-protos.h: Add prototypes for
4335 incdec_operand and eqne_operator.
4336 * config/h8300/h8300.c (incdec_operand): New.
4337 (eqne_operator): Likewise.
4338 * config/h8300/h8300.h (CONST_OK_FOR_M): Likewise.
4339 (CONST_OK_FOR_O): Likewise.
4340 (CONST_OK_FOR_LETTER_P): Use CONST_OK_FOR_M and
4341 CONST_OK_FOR_O.
4342 * config/h8300/h8300.md (UNSPEC_INCDEC): New.
4343 (addhi3_incdec): New.
4344 (addsi3_incdec): Likewise.
4345 (two peepholes): Likewise.
4346
b47900aa
KH
43472002-12-20 Kazu Hirata <kazu@cs.umass.edu>
4348
4349 * config/h8300/h8300.c (dosize): Remove warnings.
4350 (print_operand): Likewise.
4351
3094247f
RH
43522002-12-20 Richard Henderson <rth@redhat.com>
4353
4354 * config/alpha/alpha.c (decl_has_samegp): New.
4355 (samegp_function_operand): Use it. Rename from
4356 current_file_function_operand.
4357 (direct_call_operand): Handle -msmall-text via symbol->jump.
4358 (tls_symbolic_operand_1): Use T for tprel64, t for smaller tprel.
4359 (tls_symbolic_operand_type): Likewise.
4360 (alpha_encode_section_info): Likewise. Handle -msmall-text.
4361 (alpha_function_ok_for_sibcall): Use decl_has_samegp.
4362 (alpha_end_function): Set symbol->jump for functions defined in
4363 the text section.
4364 * config/alpha/alpha-protos.h: Update.
4365 * config/alpha/alpha.h (MASK_SMALL_TEXT, TARGET_SMALL_TEXT): New.
4366 (TARGET_SWITCHES): Add -msmall-text and -mlarge-text.
4367 (PREDICATE_CODES): Update.
c14bc6db 4368 * config/alpha/alpha.md (call patterns): Update for
3094247f
RH
4369 samegp_function_operand rename; use !samegp reloc if
4370 TARGET_EXPLICIT_RELOCS.
4371 * doc/invoke.text: Document -msmall-text and -mlarge-text.
4372
8056c5f2
ID
43732002-12-20 Ian Dall <ian@sibyl.beware.dropbear.id.au>
4374
44f9a8e4
ZW
4375 * config/ns32k/ns32k.md (movdi): Use "l" instead of "f" to match
4376 all registers capable of holding a double float.
4377 (*rcond): change name of "reverse branch" insns to
4378 something more meaningful.
4379 (*rbgt, *rblt, *rbge, *rble): Reverse branches to handle IEEE
4380 comparisons properly.
4381 (*ffs): Change operand 0 from write to read-modify-write.
4382 (*ffsssi2): Drop constraints from define_expand.
8056c5f2 4383
44f9a8e4
ZW
4384 * config/ns32k/ns32k.h (STORE_RATIO, STORE_BY_PIECES): Avoid using
4385 MOVE_RATIO as default for store operations.
8056c5f2 4386
44f9a8e4
ZW
4387 * config/ns32k/ns32k.h (enum reg_class, REG_CLASS_NAMES): Add
4388 LONG_REGS class.
4389 (CANNOT_CHANGE_MODE_CLASS): Can't subreg LONG_REGS.
4390 (GO_IF_LEGITIMATE_ADDRESS): Remove spurious abort().
4391 * config/ns32k/ns32k.c (regclass_map): Add LONG_REGS class.
8056c5f2 4392
44f9a8e4
ZW
4393 * config/ns32k/STATUS: New File
4394 * config/ns32k/NOTES: New file.
8056c5f2 4395
1fec52be 43962002-12-20 Hartmut Penner <hpenner@de.ibm.com>
c14bc6db 4397
21ff35fb 4398 * doc/invoke.texi: Document -mzarch, -mesa, -mcpu= and -march=
1fec52be 4399 option for S/390 and zSeries.
44f9a8e4
ZW
4400 * config/s390/s390.c (s390_cpu, s390_cpu_string, s390_arch,
4401 s390_arch_string): New variables.
4402 (override_options): Checking for options and setting of
1fec52be 4403 appropriate target_flags, cpu and arch flags.
44f9a8e4
ZW
4404 * config/s390/s390.h: (processor_type): New enum.
4405 (TARGET_SWITCHES): New switches -mesa/zarch.
4406 * config/s390/s390.md: New attribute 'cpu'.
1fec52be 4407
5bdc5878
KH
44082002-12-19 Kazu Hirata <kazu@cs.umass.edu>
4409
4410 * c-pretty-print.h: Fix comment typos.
4411 * integrate.c: Likewise.
4412 * varasm.c: Likewise.
4413 * config/c4x/c4x.h: Likewise.
4414 * config/c4x/c4x.md: Likewise.
4415 * config/fr30/fr30.md: Likewise.
4416 * config/frv/frv.c: Likewise.
4417 * config/h8300/h8300.c: Likewise.
4418 * config/i386/i386.c: Likewise.
4419 * config/i386/i386.h: Likewise.
4420 * config/ia64/ia64.c: Likewise.
4421 * config/ia64/ia64.h: Likewise.
4422 * config/ip2k/ip2k.md: Likewise.
4423 * config/m68hc11/m68hc11-crt0.S: Likewise.
4424 * config/m68hc11/m68hc11.h: Likewise.
4425 * config/m68hc11/m68hc11.md: Likewise.
4426 * config/m68hc11/m68hc12.h: Likewise.
4427 * config/mcore/mcore.md: Likewise.
4428 * config/mips/mips.c: Likewise.
4429 * config/mips/mips.md: Likewise.
4430 * config/mmix/mmix-modes.def: Likewise.
4431 * config/pa/pa.c: Likewise.
4432 * config/rs6000/rs6000.c: Likewise.
4433 * config/rs6000/rs6000.h: Likewise.
4434 * config/rs6000/rs6000.md: Likewise.
4435
539dbd15
KH
44362002-12-19 Kazu Hirata <kazu@cs.umass.edu>
4437
4438 * config/h8300/h8300.md (output_a_shift): Clean up the code to
4439 output shifts using rotation.
4440
e505be85
ZD
44412002-12-20 Zdenek Dvorak <rakdver@atrey.karlin.mff.cuni.cz>
4442
4443 * flow.c (allocate_reg_life_data): Reset REG_FREQ.
4444
191ff852
KH
44452002-12-19 Kazu Hirata <kazu@cs.umass.edu>
4446
4447 * config/h8300/h8300.md (pushqi_h8300): Don't push the stack
4448 pointer.
4449 (pushqi_h8300hs): Likewise.
4450 (pushhi_h8300): Likewise.
4451 (pushhi_h8300hs): Likewise.
4452
b2dfd40f
R
4453Thu Dec 19 23:44:09 2002 J"orn Rennecke <joern.rennecke@superh.com>
4454
4455 * sched-rgn.c (init_regions): Update comment.
4456
310b9b1d
DE
44572002-12-19 David Edelsohn <edelsohn@gnu.org>
4458
4459 * config/rs6000/rs6000.md (define_attr type): Remove altivec.
4460 * config/rs6000/altivec.md (movv4si_internal): Set correct instruction
4461 attributes.
4462 (movv8hi_internal,movv16qi_internal,movv4sf_internal): Same.
4463 (get_vrsave_internal,set_vrsave_internal): Same.
4464 (altivec_vspltisb,altivec_vspltish,altivec_vspltisw): Same.
4465 (absv16qi2,absv8hi2,absv4si2,absv4sf2): Same
4466 (altivec_abss_v16qi,altivec_abss_v8hi,altivec_abss_v4si): Same.
4467
e91f04de
CH
44682002-12-19 Casper S. Hornstrup <chorns@users.sourceforge.net>
4469 Danny Smith <dannysmith@users.sourceforge.net>
4470 Eric Kohl <ekohl@rz-online.de>
4471
4472 * config/i386/i386.c (ix86_handle_cdecl_attribute): Check for
4473 attributes incompatible with fastcall attribute.
4474 (ix86_handle_regparm_attribute): Likewise.
4475
4476 * config/i386/i386.c (ix86_comp_type_attributes): Check for mismatched
4477 fastcall types.
4478
4479 * config/i386/cygwin.h (TARGET_OS_CPP_BUILTINS): Add fastcall
4480 attributes.
4481 (ASM_OUTPUT_LABELREF): Define as i386_pe_output_labelref.
4482 * config/i386/i386-protos.h (i386_pe_output_labelref): Declare.
4483 * config/i386/winnt.c (i386_pe_mark_dllimport). Add __imp_ prefix in
4484 i386_pe_output_labelref rather than here.
4485 (gen_fastcall_suffix): New function. Decorates a label name with the
4486 fastcall prefix (@) and the stdcall suffix.
4487 (i386_pe_encode_section_info): Call gen_fastcall_suffix() if a symbol
4488 has a fastcall attribute.
4489 (i386_pe_output_labelref): New function. Outputs a label reference.
4490 * config/i386/i386.c (ix86_attribute_table): Accept 'fastcall' as a
4491 valid attribute.
4492 (ix86_return_pops_args): Fastcall functions pop the stack.
4493 (init_cumulative_args): Reserve registers ECX and EDX if function has
4494 fastcall attribute.
4495 (function_arg): Use registers ECX and EDX if function has fastcall
4496 attribute.
4497 * config/i386/i386.h (CUMULATIVE_ARGS): Add fastcall attribute flag.
4498 (DLL_IMPORT_EXPORT_PREFIX): Redefine as '#'.
4499 (FASTCALL_PREFIX): Define as '@'.
4500 * config/i386/mingw32.h (TARGET_OS_CPP_BUILTINS): Add fastcall
4501 attributes.
4502 * doc/extend.texi: Add documentation of fastcall attribute.
4503
61138bb6
NN
45042002-12-19 Nathanael Nerode <neroden@gcc.gnu.org>
4505
c14bc6db 4506 * configure.in: FORBUILD when build!=host changed from
61138bb6
NN
4507 ../$build-alias to ../build-$build_alias to match change made
4508 in top directory.
4509 * configure: Regenerated.
4510
039baf9e
EB
45112002-12-19 Eric Botcazou <ebotcazou@libertysurf.fr>
4512
4513 PR optimization/8988
4514 * loop.c (maybe_eliminate_biv): Kill REG_EQUAL notes mentioning
4515 the biv when eliminating.
4516
ee8acf89
DP
45172002-12-19 Devang Patel <dpatel@apple.com>
4518 * gcc.c (struct default_compiler): Recognizes input file name with
4519 .CPP extension as C++ source files
4520 * cp/lang-spec.h: Same
4521 * doc/invoke.texi: Add documentation for .CPP support.
c14bc6db 4522
598119bb
AH
45232002-12-19 Aldy Hernandez <aldyh@redhat.com>
4524
4525 PR 8553
4526 * config/rs6000/altivec.md ("absv8hi2"): Add & to clobbered
4527 registers.
4528 ("absv16qi2"): Same.
4529 ("absv4si2"): Same.
4530 ("absv4sf2"): Same.
4531 ("altivec_abss_v16qi"): Same.
4532 ("altivec_abss_v8hi"): Same.
4533 ("altivec_abss_v4si"): Same.
4534
3af97654
UW
45352002-12-19 Ulrich Weigand <uweigand@de.ibm.com>
4536
4537 * config/s390/s390.md ("*tsthiCCT", "*tsthiCCT_cconly",
4538 "*tstqiCCT", "*tstqiCCT_cconly"): New insns.
4539
e54b4cae
EB
45402002-12-19 Eric Botcazou <ebotcazou@libertysurf.fr>
4541
4542 PR target/8340
4543 * stmt.c (expand_asm_operands): Produce an error when
4544 the PIC register is clobbered.
4545
7f22efe1
DB
45462002-12-18 Daniel Berlin <dberlin@dberlin.org>
4547
4548 * Makefile.in (OBJS): Add alloc-pool.o
4549 (alloc-pool.o): New object.
4550
4551 * alloc-pool.c: New file.
4552 * alloc-pool.h: New file.
4553
f1d5271a 45542002-12-18 Loren James Rittle <ljrittle@acm.org>
5a0ba8c9
LJR
4555
4556 * gcc.c (validate_switches): Robustify against skipping past '\0'.
4557
064b6c70
GK
45582002-12-18 Geoffrey Keating <geoffk@apple.com>
4559
4560 * config.gcc: Set extra_objs in the generic Darwin rule,
4561 not in the machine-specific rules.
4562
272d0bee
KH
45632002-12-19 Kazu Hirata <kazu@cs.umass.edu>
4564
4565 * ChangeLog: Follow spelling conventions.
4566 * ChangeLog.2: Likewise.
4567 * ChangeLog.4: Likewise.
4568 * ChangeLog.5: Likewise.
4569 * cppexp.c: Likewise.
4570 * df.c: Likewise.
4571 * gcov.c: Likewise.
4572 * gengtype.c: Likewise.
4573 * reload1.c: Likewise.
4574 * sched-rgn.c: Likewise.
4575 * stmt.c: Likewise.
4576 * stor-layout.c: Likewise.
4577 * timevar.c: Likewise.
4578 * toplev.c: Likewise.
4579 * tree.h: Likewise.
4580 * varasm.c: Likewise.
4581 * config/fr30/fr30.md: Likewise.
4582 * config/i386/i386.c: Likewise.
4583 * config/ia64/ia64.c: Likewise.
4584 * config/pa/pa.c: Likewise.
4585
358ecb10
RS
45862002-12-18 Roger Sayle <roger@eyesopen.com>
4587
4588 * basic-block.h (flow_bb_inside_loop_p): Correct prototype.
4589
d486dec6
AH
45902002-12-18 Aldy Hernandez <aldyh@redhat.com>
4591
7f04df0d 4592 PR 8551
d486dec6
AH
4593 * config/rs6000/altivec.h (vec_cmplt macro): Reverse arguments in
4594 macro.
4595 (vec_cmplt C++ functions): Reverse arguments.
4596
358ecb10 45972002-12-18 Geoffrey Keating <geoffk@apple.com>
892aebc9 4598
40b4cdbf
GK
4599 * config/rs6000/t-rs6000: Move contents to t-fprules,
4600 add rules for dependencies of rs6000.o and to build rs6000-c.o
4601 * config/rs6000/t-fprules: New file from t-rs6000.
4602 * config/rs6000/t-beos: Remove soft-fp rules.
4603 * config/rs6000/t-ppccomm: Likewise.
4604 * config/rs6000/t-newas: Likewise.
4605 * config/rs6000/t-rs6000-c-rule: Delete.
4606 * config.gcc: Use t-fprules for rs6000/ ports when appropriate.
4607 Use t-rs6000 for all rs6000/ ports instead of t-rs6000-c-rule.
4608 Create generic Darwin rules.
4609
892aebc9
GK
4610 * gengenrtl.c (gencode): Delete unnecessary rtl_obstack declaration.
4611
9d303046
DE
46122002-12-18 Doug Evans <dje@sebabeach.org>
4613
4614 * m32r/m32r.c (addr24_operand): Fix arg to CONSTANT_POOL_ADDRESS_P
4615 and LIT_NAME_P.
4616 (move_src_operand): Remove compile-time warning.
4617 * m32r/m32r.h (ROUND_ADVANCE_ARG): Ditto.
4618
80d83b16
JM
46192002-12-18 Jason Merrill <jason@redhat.com>
4620
4621 * unwind-dw2-fde.c (frame_downheap): Split out from...
4622 (frame_heapsort): Here.
4623
f32ac70d
JM
46242002-12-17 Jason Merrill <jason@redhat.com>
4625
9ec22713
JM
4626 * tree.c (make_node): Don't set TREE_TYPE on 's' class nodes.
4627 (build1): Always set TREE_SIDE_EFFECTS on 's' class nodes.
4628
38540594 4629 * gcc.c (do_spec_1) ['W']: End any pending argument from the braces.
a3a0177e 4630
f32ac70d
JM
4631 * calls.c (expand_call): Don't try to be clever about expanding
4632 the return slot address.
4633
d5db5b97
KK
46342002-12-18 Kaz kojima <kkojima@gcc.gnu.org>
4635
4636 * config/sh/linux.h (NO_IMPLICIT_EXTERN_C, CPLUSPLUS_CPP_SPEC):
4637 Define.
4638
e489a31f
JM
46392002-12-17 Jason Merrill <jason@redhat.com>
4640
4641 * genmultilib: Use 'cd ./foo'.
4642
5b8f02c6
KH
46432002-12-17 Kazu Hirata <kazu@cs.umass.edu>
4644
4645 * doc/c-tree.texi: Restore deliberate spelling mistakes.
4646
c0478a66
KH
46472002-12-17 Kazu Hirata <kazu@cs.umass.edu>
4648
4649 * doc/c-tree.texi: Fix typos and follow spelling conventions.
4650 * doc/cpp.texi: Likewise.
4651 * doc/extend.texi: Likewise.
4652 * doc/gty.texi: Likewise.
4653 * doc/install.texi: Likewise.
4654 * doc/invoke.texi: Likewise.
4655 * doc/md.texi: Likewise.
4656 * doc/passes.texi: Likewise.
4657 * doc/rtl.texi: Likewise.
4658 * doc/sourcebuild.texi: Likewise.
4659 * doc/tm.texi: Likewise.
4660
3364c33b
JQ
46612002-12-17 Jerry Quinn <jlquinn@optonline.net>
4662
4663 * doc/invoke.texi: Minor spelling and grammar fixes.
4664
d65f135a
UW
46652002-12-17 Ulrich Weigand <uweigand@de.ibm.com>
4666
4667 * config/s390/s390.c (s390_output_constant_pool): Replace
4668 ASM_OUTPUT_INTERNAL_LABEL by (*targetm.asm_out.internal_label).
4669
4b207444
JH
4670Tue Dec 17 09:47:57 CET 2002 Jan Hubicka <jh@suse.cz>
4671
4672 * convert.c (convert_to_real): Disable function transformation for
4673 now.
4674
cde26509
GK
46752002-12-16 Geoffrey Keating <geoffk@apple.com>
4676
4677 * gcc.c (handle_braces): Allow '@' as a switch name.
4678
9f175208
JM
46792002-12-16 Jason Merrill <jason@redhat.com>
4680
e489a31f
JM
4681 * calls.c (expand_call): Handle CALL_EXPR_HAS_RETURN_SLOT_ADDR
4682 with special struct-return ABIs.
4683
9f175208
JM
4684 * c-semantics.c (add_scope_stmt): Abort if the end SCOPE_STMT
4685 doesn't match the begin SCOPE_STMT in partialness.
4686
7a975113
GK
46872002-12-16 Geoffrey Keating <geoffk@apple.com>
4688
c79d892f
GK
4689 * genmultilib: Create temporary files in unique subdirectory.
4690
7a975113
GK
4691 * gcc.c (validate_switches): Allow '@' as a switch name.
4692
8483c7e0
LR
46932002-12-16 Loren J. Rittle <ljrittle@acm.org>
4694
4695 * Makefile.in (gcov-iov.h): Improve portability.
4696
9ee7999f
JH
4697Mon Dec 16 23:39:19 CET 2002 Jan Hubicka <jh@suse.cz>
4698
4699 * mips.h (ASM_OUTPUT_ADDR_DIFF_ELT): Do not use qpword on API_N32/not
4700 gas
4701 * mips.md (tablejump insn): Likewise.
4702
7a04c51b
MM
47032002-12-16 Mark Mitchell <mark@codesourcery.com>
4704
4705 * doc/include/gcc-common.texi: Change version number to 3.4.
4706
27eaa708
BK
47072002-12-16 Bruce Korb <bkorb@gnu.org>
4708
4709 * fixinc/fixlib.h: add: #include <signal.h>
4710 * fixinc/fixincl.c: remove: #include <signal.h>
4711
b51dc045
R
4712Mon Dec 16 17:20:04 2002 J"orn Rennecke <joern.rennecke@superh.com>
4713
4714 * sh.h (EXTRA_CONSTRAINT_Z): New macro.
4715 (EXTRA_CONSTRAINT): Use it.
4716 * sh.md (anddi3): Use 'Z' constraint for alternative 2.
4717
4977bab6
ZW
47182002-12-15 Zack Weinberg <zack@codesourcery.com>
4719
4720 * config.gcc (need_64bit_hwint): New variable.
4721 (alpha*-*-*, x86_64-*-*, ia64-*-*, mips*-*-*, powerpc*-*-*,
4722 mmix-knuth-mmixware, rs6000*-*-*, sparc64*-*-*, s390*-*-*,
4723 sh*-*-*, hppa*64*-*-linux, parisc*64*-*-linux, hppa*64*-*-hpux11*,
4724 sparcv9-*-solaris2*, sparc*-*-solaris2.[789], ultrasparc-*-freebsd*):
4725 Set it.
4726 (powerpc*-*-darwin*): Unset it.
4727 (alpha-*-interix, alpha64-dec-*vms*, i?86-*-interix3*,
4728 i?86-*-interix*, sparc64-*-openbsd*): Remove references to
4729 deleted/nonexistent xm-*.h headers.
4730 * configure.in: AC_DEFINE NEED_64BIT_HOST_WIDE_INT if the
4731 target set need_64bit_hwint in config.gcc.
4732 * configure, config.in: Regenerate.
4733
4734 * hwint.h: Overhaul. Don't bother trying int for
4735 HOST_WIDE_INT. Do try __int64 if long is not enough. Base
4736 decision to force 64-bit HOST_WIDE_INT on
4737 NEED_64BIT_HOST_WIDE_INT, not (MAX_)LONG_TYPE_SIZE which is
4738 not visible at this point. Don't allow prior definition of
4739 any macro defined by this file.
4740
4741 * config/alpha/xm-vms.h: Don't define HOST_WIDE_INT or
4742 HOST_BITS_PER_WIDE_INT.
4743 * config/c4x/c4x.h: Adjust redefinition of
4744 HOST_WIDE_INT_PRINT_HEX to match changes to hwint.h.
4745 * config/alpha/xm-alpha-interix.h, config/alpha/xm-vms64.h,
4746 config/i386/xm-i386-interix.h: Delete file.
4747
47482002-12-14 Rodney Brown <rbrown64@csc.com.au>
4749 John David Anglin <dave@hiauly1.hia.nrc.ca>
4750
4751 * pa.c (output_millicode_call): Convert ASM_OUTPUT_INTERNAL_LABEL.
4752 * pa64-hpux.h (ASM_OUTPUT_INTERNAL_LABEL): Delete define.
4753
47542002-12-14 Zack Weinberg <zack@codesourcery.com>
4755
4756 * mkconfig.sh: Correct comment. Add copyright boilerplate.
4757
47582002-12-14 Zack Weinberg <zack@codesourcery.com>
4759
4760 * config/t-darwin, config/arm/t-pe, config/arm/t-strongarm-pe,
4761 config/c4x/t-c4x, config/i370/t-i370, config/i386/t-cygwin,
4762 config/i386/t-interix, config/i960/t-960bare, config/ia64/t-ia64,
4763 config/rs6000/t-rs6000-c-rule, config/sparc/t-sol2,
4764 config/v850/t-v850: Correct dependencies and normalize
4765 compilation commands for files that include coretypes.h and tm.h.
4766
4767 * config/sparc/gmon-sol2.c: Include tconfig.h and tsystem.h,
4768 not config.h and system.h.
4769
4770Sat Dec 14 20:43:41 CET 2002 Jan Hubicka <jh@suse.cz>
4771
4772 * i386.c (flags_reg_operand): New function.
4773 * i386.h (PREDICATE_CODES): Add flags_reg_operand.
4774 * i386.md (cmov splitter, movqicc): Use new predicate.
4775
4776Sat Dec 14 17:03:17 CET 2002 Jan Hubicka <jh@suse.cz>
4777
4778 * i386.md (movqicc splitter): Fix template.
4779
47802002-12-13 Jason Merrill <jason@redhat.com>
4781
4782 * tree.h (CALL_EXPR_HAS_RETURN_SLOT_ADDR): New macro.
4783 * calls.c (expand_call): Handle it.
4784 * tree-inline.c (struct inline_data): Remove target_exprs field.
4785 (optimize_inline_calls): Don't initialize it.
4786 (expand_call_inline): Don't modify it. Handle
4787 CALL_EXPR_HAS_RETURN_SLOT_ADDR.
4788 (declare_return_variable): Take return slot addr.
4789 * langhooks.h (copy_res_decl_for_inlining): Change target_exprs parm
4790 to return_slot_addr.
4791 * langhooks-def.h, langhooks.c: Adjust.
4792 * explow.c (maybe_set_unchanging): Don't set RTX_UNCHANGING_P for
4793 a decl with no DECL_INITIAL.
4794
4795 * expr.c (expand_expr): Don't discard the target of a call which
4796 returns in memory.
4797
47982002-12-13 Neil Booth <neil@daikokuya.co.uk>
4799
4800 * cppinit.c (path_include): Take an environment variable name.
4801 Tidy up.
4802 (init_standard_includes): Simplify environment handling, and
4803 move to ...
4804 (cpp_read_main_file): ...here as -nostdinc should not affect
4805 environment variable paths.
4806
f5f9008b
JDA
48072002-12-13 John David Anglin <dave@hiauly1.hia.nrc.ca>
4808
4809 * pa.c (output_millicode_call): Correct typo.
4810 (output_call): Likewise.
4811
a58be199
AO
4812Fri Dec 13 21:07:18 2002 Alexandre Oliva <aoliva@redhat.com>
4813
4814 * config/mn10300/mn10300.c (print_operand) <case N>: Check
4815 operand's range. Print value directly, without aid from
4816 output_address.
4817 <case U>: New.
4818 <case S>: Make sure argument to fprintf has the right type.
4819 * config/mn10300/mn10300.h (OK_FOR_T): New macro.
4820 (EXTRA_CONSTRAINT): Adjust.
4821 * config/mn10300/mn10300.md: Add new all-QImode pattern for
4822 bclr. Use %U for immediate operands of bset and bclr.
4823 (iorqi3): New expand, with insns for AM33 and mn10300.
4824
d9da94a1
R
4825Fri Dec 13 16:02:27 2002 J"orn Rennecke <joern.rennecke@superh.com>
4826
4827 * sh.c (sh_register_operand): New function.
4828 (prepare_move_operands): Use it.
4829 * sh.h (PREDICATE_CODES): Add entry for sh_register_operand.
4830 * sh.md (movsi_media, movsi_media_nofpu): Allow stores of 0.
4831 (movqi_media, movhi_media, movdi_media, movdi_media_nofpu): Likewise.
4832 (movdf_media, movdf_media_nofpu, movv4sf_i, movsf_media): Likewise.
4833 (movsf_media_nofpu, movv2hi_i, movv4hi_i, movv8qi_i): Likewise.
4834 (movv2si_i): Likewise.
4835
580fb356
JW
48362002-12-13 Jim Wilson <wilson@redhat.com>
4837
4838 * doc/extend.texi (Complex Numbers): Update info on debug info.
4839
697d8028
KH
48402002-12-13 Kazu Hirata <kazu@cs.umass.edu>
4841
4842 * config/h8300/h8300.md (addhi3_h8300): Remove the last
4843 alternative.
4844
4977bab6
ZW
48452002-12-12 Zdenek Dvorak <rakdver@atrey.karlin.mff.cuni.cz>
4846
4847 * hooks.h (hook_tree_tree_bool_false): Declare
4848 hook_bool_tree_tree_false instead.
4849
dd05b1b4 48502002-12-12 Devang Patel <dpatel@apple.com>
697d8028 4851
dd05b1b4
DP
4852 * doc/invoke.texi: Document Darwin linker options, -bundle
4853 -bind_at_load, -all_load and -arch_errors_fatal
4854
24aacafb
JW
48552002-12-12 Jim Wilson <wilson@redhat.com>
4856
4857 * dbxout.c (dbxout_fptype_value): New.
4858 (dbxout_type, case COMPLEX_TYPE): Call it. Use 'R' instead of 'r'.
4859
09da1532
KH
48602002-12-12 Kazu Hirata <kazu@cs.umass.edu>
4861
4862 * c-decl.c: Fix a comment typo.
4863 * cfg.c: Likewise.
4864 * cfgcleanup.c: Likewise.
4865 * cfglayout.c: Likewise.
4866 * cfgrtl.c: Likewise.
4867 * c-typeck.c: Likewise.
4868 * dominance.c: Likewise.
4869 * dwarf2asm.c: Likewise.
4870 * dwarfout.c: Likewise.
4871 * expmed.c: Likewise.
4872 * expr.c: Likewise.
4873 * final.c: Likewise.
4874 * flow.c: Likewise.
4875 * function.c: Likewise.
4876 * gcc.c: Likewise.
4877 * genautomata.c: Likewise.
4878 * integrate.c: Likewise.
4879 * loop.c: Likewise.
4880 * loop.h: Likewise.
4881 * output.h: Likewise.
4882 * profile.c: Likewise.
4883 * ra.h: Likewise.
4884 * reload1.c: Likewise.
4885 * reload.c: Likewise.
4886 * sched-rgn.c: Likewise.
4887 * stmt.c: Likewise.
4888 * tree.h: Likewise.
4889 * vmsdbgout.c: Likewise.
4890
7930523d
KH
48912002-12-12 Kazu Hirata <kazu@cs.umass.edu>
4892
4893 * config/h8300/h8300.md: Add a new peephole2.
4894
59578c84
KH
48952002-12-12 Kazu Hirata <kazu@cs.umass.edu>
4896
4897 * config/h8300/h8300.md (a peephole2): Accept a constant
4898 that's accepted by CONST_OK_FOR_J.
4899
8cc5359b
KH
49002002-12-12 Kazu Hirata <kazu@cs.umass.edu>
4901
4902 * config/h8300/h8300.h (CONST_OK_FOR_J): New.
4903 (CONST_OK_FOR_LETTER_P): Use CONST_OK_FOR_J.
4904 * config/h8300/h8300.md (*addhi_h8300): Add a new alternative.
4905 (*addhi_h8300hs): Likewise.
4906
ec555f32
R
4907Thu Dec 12 16:24:59 2002 J"orn Rennecke <joern.rennecke@superh.com>
4908
4909 * sh.c (reg_class_from_letter): No longer const. Add 'e' entry.
4910 (sh_register_move_cost): Add clause for SImode fp-fp moves.
4911 Increase cost for moves involving multiple general purpose registers.
4912 * sh.h (OVERRIDE_OPTIONS): Set reg_class_from_letter['e'] according to
4913 TARGET_FMOVD.
4914 (HARD_REGNO_MODE_OK): Allow V2SFmode and V4SFmode in general purpose
4915 registers, and SImode in fp registers, for ! TARGET_SHMEDIA.
4916 (enum reg_class reg_class_from_letter): No longer const.
4917 (SECONDARY_OUTPUT_RELOAD_CLASS): Use REGCLASS_HAS_FP_REG /
4918 REGCLASS_HAS_GENERAL_REG.
4919 Handle SImode moves from/to fp registers.
4920 ! TARGET_SHMEDIA && TARGET_FMOVD.
4921 (SECONDARY_INPUT_RELOAD_CLASS): Use REGCLASS_HAS_FP_REG.
4922 * sh.md (movsi_ie): Add alternatives to move from / to fp regisyters.
4923
83ebfdc0
AS
49242002-12-12 Andreas Schwab <schwab@suse.de>
4925
4926 * config/ia64/ia64.c (ia64_hpux_asm_file_end): Fix typo in last
4927 change and some warnings.
4928
299c5111
KH
49292002-12-12 Kazu Hirata <kazu@cs.umass.edu>
4930
4931 * doc/md.texi (pushm): Fix a typo.
4932
852dff61
AO
49332002-12-12 Alexandre Oliva <aoliva@redhat.com>
4934
4935 * config/mips/mips.c (mips_output_conditional_branch): Support
4936 PIC-safe out-of-range branch and branch-likely.
4937 * config/mips/mips.md (attr length): PIC-safe out-of-range
4938 branches are longer.
4939 ("jump"): Support PIC-safe out-of-range-for-branch jumps. Remove
4940 unused code to support indirect jumps.
4941
4977bab6
ZW
49422002-12-11 Zack Weinberg <zack@codesourcery.com>
4943
4944 * Makefile.in (GTFILES): Add $(host_xm_file_list) and
4945 $(tm_file_list).
4946
49472002-12-11 David Edelsohn <edelsohn@gnu.org>
4948
4949 * config/rs6000/t-rs6000-c-rule: Add coretypes.h $(TM_H) dependencies.
4950
4951Wed Dec 11 15:20:45 CET 2002 Jan Hubicka <jh@suse.cz>
4952
4953 * i386.md (cmove splitters): Avoid creation of unnecesary subregs.
4954
d6567b3a
JDA
49552002-12-11 John David Anglin <dave@hiauly1.hia.nrc.ca>
4956
4957 * pa.h (BIGGEST_ALIGNMENT): Change 32-bit value to 64 bits.
4958 (MAX_PARM_BOUNDARY, STACK_BOUNDARY): Express in terms of
4959 BIGGEST_ALIGNMENT.
4960 (PREFERRED_STACK_BOUNDARY): Express in terms of STACK_BOUNDARY.
4961 (FUNCTION_BOUNDARY): Express in terms of BITS_PER_WORD.
4962
355bd14f
KH
49632002-12-11 Kazu Hirata <kazu@cs.umass.edu>
4964
4965 * doc/invoke.texi: Correct dump file names.
4966
9a3873b4
SE
49672002-12-09 Steve Ellcey <sje@cup.hp.com>
4968
4969 * config/ia64/ia64.c (ia64_hpux_asm_file_end): Don't send stripped
4970 name to globalize_label or assemble_name.
4971
9a4816af
R
4972Wed Dec 11 20:15:19 2002 J"orn Rennecke <joern.rennecke@superh.com>
4973
4974 * sh.h (REG_CLASS_HAS_GENERAL_REG): Only true for SIBCALL_REGS
4975 if not TARGET_SHMEDIA.
4976
4977Wed Dec 11 19:05:05 2002 J"orn Rennecke <joern.rennecke@superh.com>
4978
4979 * sh.h (REG_CLASS_HAS_FP_REG): New.
4980 (REGISTER_MOVE_COST) Use it. Put body into a function and
4981 move it into:
4982 * sh.c (sh_register_move_cost).
4983 * sh-protos.h (sh_register_move_cost): Declare.
4984
4985 * sh.c (sh_expand_builtin): Abort for unexpected nop values.
4986 (sh_adjust_cost): Always return a value.
4987
70a72ca4
R
4988Wed Dec 11 18:39:52 2002 J"orn Rennecke <joern.rennecke@superh.com>
4989
4990 * sh.h (REG_CLASS_HAS_GENERAL_REG): New.
4991 (REGISTER_MOVE_COST): Use it.
4992
5d5cd66f
RH
49932002-12-11 Richard Henderson <rth@redhat.com>
4994
4995 * tree.h (MODULE_LOCAL_P): Kill.
4996 * varasm.c (default_binds_local_p_1): Use decl_visibility instead.
4997
68d0a3d2
KH
49982002-12-11 Kazu Hirata <kazu@cs.umass.edu>
4999
5000 * config/h8300/h8300.md (two define_peephole2): New.
5001
722d59a3
KH
50022002-12-11 Kazu Hirata <kazu@cs.umass.edu>
5003
5004 * config/h8300/h8300.h (CONST_OK_FOR_J): Remove.
5005 (CONST_OK_FOR_K): Likewise.
5006 (CONST_OK_FOR_M): Likewise.
5007 (CONST_OK_FOR_LETTER_P): Do not use the above macros.
5008
b3a5a50c
NB
50092002-12-11 Neil Booth <neil@daikokuya.co.uk>
5010
5011 * c-common.c (builtin_define_type_max): Handle unsigned
5012 types too.
5013
4977bab6
ZW
50142002-12-10 David Edelsohn <edelsohn@gnu.org>
5015
5016 * haifa-sched.c (rank_for_schedule): Correct style.
5017
50182002-12-10 Per Bothner <pbothner@apple.com>
5019
5020 * cpplib.h (struct cpp_hashnode): Split a non-portably-signed field
5021 directive_index into an unsigned field and a new is_directive field.
5022 * cppinit.c (mark_named_operators): Update to set new fields.
5023 * cpplex.c (_cpp_lex_direct): Now directive_field is unsigned.
5024 * cpplib.c [_cpp_handle_directive]: Test is_directive field.
5025 No longer need to subtract 1 from directive_index.
5026 (_cpp_init_directives): No longer need to add 1 to directive_index.
5027 * cpptrad.c (scan_out_logical_line): Use is_directive field.
5028
50292002-12-10 Roger Sayle <roger@eyesopen.com>
5030
5031 * builtins.c (fold_builtin): Remove -funsafe-math-optimizations
5032 check for evaluating sqrt of a constant at compile time.
5033 * simplify-rtx.c (simplify_unary_operation): Likewise.
5034
40d81ee4
JJ
50352002-12-10 Janis Johnson <janis187@us.ibm.com>
5036
5037 PR other/8882
5038 * doc/tm.texi (PUSH_ARGS): Remove misplaced line.
5039
48aec0bc 50402002-12-10 Devang Patel <dpatel@appple.com>
40d81ee4 5041
48aec0bc
DP
5042 * config/darwin.h(LINK_SPEC): Add darwin specific linker options.
5043 * doc/invoke.texi: Add new "Darwin Options" section.
4977bab6 5044
0e9f8e82
JW
50452002-12-10 Jim Wilson <wilson@redhat.com>
5046
5047 * rs6000.h (RETURN_IN_MEMORY): If ABI_V4, then TFmode is returned in
5048 memory.
5049
3e25353e
AH
50502002-12-10 Andrew Haley <aph@redhat.com>
5051
5052 * cse.c (cse_insn): Don't cse past a basic block boundary.
5053
17772b2a
JJ
50542002-12-10 Jakub Jelinek <jakub@redhat.com>
5055
5056 * config/linux.h (LIB_SPEC): If -pthread, add -lpthread even if
5057 -shared.
5058 * config/alpha/linux-elf.h (LIB_SPEC): Likewise.
5059 * config/alpha/linux.h (LIB_SPEC): Likewise.
5060 * config/arm/linux-elf.h (LIB_SPEC): Likewise.
5061 * config/pa/pa-linux.h (LIB_SPEC): Likewise.
5062 * config/sparc/linux.h (LIB_SPEC): Likewise.
5063 * config/sparc/linux64.h (LIB_SPEC): Likewise.
5064
63358530
LH
50652002-12-09 Larin Hennessy <larin@science.oregonstate.edu>
5066
5067 * doc/invoke.texi: Document UltraSparc III option.
5068
2e37b0ce
RH
50692002-12-09 Richard Henderson <rth@redhat.com>
5070
5071 * config/i386/i386.h (TARGET_CPU_CPP_BUILTINS): Define
5072 __tune_pentium2__ and __tune_pentium3__ as necessary.
5073
3a04ff64
RH
50742002-12-09 Richard Henderson <rth@redhat.com>
5075
5076 * target.h (gcc_target): Add cannot_force_const_mem.
5077 * target-def.h (TARGET_CANNOT_FORCE_CONST_MEM): New.
5078 (TARGET_INITIALIZER): Add it.
5079 * varasm.c (force_const_mem): Fail if cannot_force_const_mem.
5080 * expr.c (emit_move_insn): Be prepared for force_const_mem to fail.
5081 * reload1.c (reload): Likewise.
5082 * hooks.c (hook_bool_rtx_false): New.
5083 * hooks.h: Declare it.
5084
5085 * config/i386/i386.c (ix86_cannot_force_const_mem): New.
5086 (TARGET_CANNOT_FORCE_CONST_MEM): New.
5087 (ix86_expand_move): Remove de-const-pooling hack.
5088
a9a4005f
JH
5089Mon Dec 9 21:33:38 CET 2002 Jan Hubicka <jh@suse.cz>
5090
5091 * toplev.c (dump_file): Fix order to match reality.
5092
7ef788f0
GK
50932002-12-08 Geoffrey Keating <geoffk@apple.com>
5094
5095 * config/rs6000/rs6000.md (load_multiple): Use adjust_address_nv.
5096 (store_multiple): Likewise.
5097
3f320b7e
JDA
50982002-12-09 John David Anglin <dave@hiauly1.hia.nrc.ca>
5099
5100 * pa/fptr.c (__canonicalize_funcptr_for_compare): Don't canonicalize
5101 function pointers in page 0.
5102
3870df96
SE
51032002-12-09 Steve Ellcey <sje@cup.hp.com>
5104
5105 * config/ia64/hpux.h (TARGET_STRUCT_ARG_REG_LITTLE_ENDIAN): Remove
5106 definition
5107 (MEMBER_TYPE_FORCES_BLK): Move.
5108 * config/ia64/ia64.c (ia64_function_arg): Use PARALLEL to pass
5109 aggregate arguments.
5110 (ia64_function_value): Use PARALLEL to return aggregate values.
5111
9ac3e73b
SE
51122002-12-09 Steve Ellcey <sje@cup.hp.com>
5113
5114 * doc/tm.texi (FUNCTION_ARG_REG_LITTLE_ENDIAN): Remove definition.
5115 * defaults.h (FUNCTION_ARG_REG_LITTLE_ENDIAN): Remove definition.
5116 * calls.c (store_unaligned_arguments_into_pseudos) Remove
5117 FUNCTION_ARG_REG_LITTLE_ENDIAN.
5118 * stmt.c (expand_return): Ditto.
5119 * expr.c (move_block_from_reg): Ditto.
5120 (copy_blkmode_from_reg): Ditto.
4977bab6 5121 * expmed.c (store_bit_field): Ditto.
9ac3e73b 5122
7f0db92a
SS
51232002-12-09 Svein E. Seldal <Svein.Seldal@solidas.com>
5124
5125 * config.gcc: Added tic4x-* target as an alias to c4x-*
5126
37c66aa6
JH
5127Sun Dec 8 14:57:39 CET 2002 Jan Hubicka <jh@suse.cz>
5128
7ef788f0
GK
5129 * i386.c (ix86_expand_int_movcc): Use force_operand instead of
5130 constructing insn directly.
37c66aa6 5131
4977bab6
ZW
51322002-12-06 Per Bothner <pbothner@apple.com>
5133
5134 * cpplib.h (struct cpp_hashnode): Change field directive_index from
5135 char to an int bit-field, for hosts where char is unsigned.
5136
51372002-12-07 Roger Sayle <roger@eyesopen.com>
5138 Richard Henderson <rth@redhat.com>
5139
5140 * real.c (ieee_extended_motorola_format,
5141 ieee_extended_intel_96_format, ieee_extended_intel_128_format,
5142 ieee_quad_format, vax_d_format, vax_g_format, i370_double_format):
5143 Provide appropriate values for new signbit field.
5144
51452002-12-07 Roger Sayle <roger@eyesopen.com>
5146
5147 * real.h (real_format): Add signbit field.
5148 * real.c (ieee_single_format, ieee_double_format,
5149 ieee_extended_motorola_format, ieee_extended_intel_96_format,
5150 ieee_extended_intel_128_format, ibm_extended_format,
5151 ieee_quad_format, vax_f_format, vax_d_format,
5152 vax_g_format, i370_single_format, i370_double_format,
5153 c4x_single_format, c4x_extended_format, real_internal_format):
5154 Provide suitable signbit value, or -1 to avoid bit twiddling.
5155
5156 * optabs.c (expand_unop): Try implementing negation of
5157 floating point modes by flipping the sign bit.
5158 (expand_abs): Try implementing abs of floating point modes
5159 by clearing the sign bit.
5160
5161Sat Dec 7 22:29:47 CET 2002 Jan Hubicka <jh@suse.cz>
5162
5163 * i386.c (ix86_expand_int_movcc): Use force_operand instead
5164 of constructing insn directly.
5165
2a598b3a
KH
51662002-12-07 Kazu Hirata <kazu@cs.umass.edu>
5167
5168 * config/h8300/h8300.md (*iorhi_shift_8): New.
5169
70899148
BS
51702002-12-06 Bernd Schmidt <bernds@redhat.com>
5171
5172 * doc/invoke.texi: Document FRV port options.
5173 * doc/md.texi: Document FRV register classes.
5174
377dfc82
GP
51752002-12-07 Gerald Pfeifer <pfeifer@dbai.tuwien.ac.at>
5176
5177 * doc/install.texi (Configuration): Improve description of cases
5178 where `make distclean` may fail; clarify --with-gnu-as; fix grammar.
5179
4977bab6
ZW
51802002-12-06 Per Bothner <pbothner@apple.com>
5181
5182 * cpplib.h (NODE_MACRO_ARG): New flag.
5183 (struct cpp_hashnode): Give _cpp_hashnode_value tag to value union.
5184 Remove value.operator field. Move arg_index field to value union.
5185 (directive_index): Make signed, since also used for C++ operators.
5186 * cppmacro.c (_cpp_save_parameter): Use NODE_MACRO_ARG flag to
5187 check for duplicate parameter. Set NODE_MACRO_ARG flag.
5188 Save node->value, and set node->value.arg_index.
5189 (_cpp_create_definition): For each paramater, restore node->value.
5190 (lex_expansion_token): Use NODE_MACRO_ARG flag, and moved arg_index.
5191 * cpptrad.c (scan_out_logical_line): Likewise.
5192 (scan_out_logical_line): Check for directive > 0.
5193 * cpplib.c (cpp_handle_directive): Likewise.
5194 * cpplex.c (_cpp_lex_direct): Update as value.operator is replaced
5195 by negative of directive_index.
5196 * cppinit.c (mark_named_operators): Likewise.
5197
5198 * hashtable.h (struct ht_identifier): Swap fields, for better packing.
5199
7144b2d8
DD
52002002-12-06 Dhananjay Deshpande <dhananjayd@kpit.com>
5201
5202 * gcc/config/sh/sh.c (calc_live_regs): Save fpscr only if target has
5203 FPU.
5204 (push): Generate push_fpscr.
5205 (pop): Generate pop_fpscr.
5206 * gcc/config/sh/sh.md : Add define_expand "push_fpscr", "pop_fpscr".
5207 (fpu_switch): Add alternative to push fpscr. Enable for TARGET_SH3E.
5208
aa06e8f5
R
5209Fri Dec 6 19:36:24 2002 J"orn Rennecke <joern.rennecke@superh.com>
5210
5211 * sh.c (dump_table): DImode pool constants need only 32 bit alignment.
5212 DFmode alignment depends on TARGET_FMOVD && TARGET_ALIGN_DOUBLE.
5213
0113c3c0
R
5214Fri Dec 6 19:17:49 2002 J"orn Rennecke <joern.rennecke@superh.com>
5215
5216 * sh.md (movdi_i): Name. Remove inappropriate comment.
5217
8d6b008d
R
5218Fri Dec 6 15:44:46 2002 J"orn Rennecke <joern.rennecke@superh.com>
5219 Merged from basic improvements branch (excerpt):
5220
5221 2002-11-19 Kaz Kojima <kkojima@gcc.gnu.org>
5222 * config/sh/sh.h (SH_DBX_REGISTER_NUMBER): Handle PR_MEDIA_REG.
5223
61f6c84f
JJ
52242002-12-06 Jakub Jelinek <jakub@redhat.com>
5225
5226 * expr.c (expand_expr) <case COND_EXPR>: Never modify exp in place.
5227
4977bab6
ZW
5228Thu Dec 5 16:58:25 CET 2002 Jan Hubicka <jh@suse.cz>
5229
5230 * i386.md (dimode peep2s): Re-add "&& 1".
5231
5232Thu Dec 5 14:10:15 CET 2002 Jan Hubicka <jh@suse.cz>
5233
5234 * i386.c (ix86_expand_prologue): Add comment, do not use
5235 fast prologues for cold and normal functions.
5236
5237Thu Dec 5 00:52:37 CET 2002 Jan Hubicka <jh@suse.cz>
5238
5239 * i386.c (x86_rep_movl_optimal): New variable.
5240 (ix86_expand_movstr, ix86_expand_clrstr): Use TARGET_REP_MOVL_OPTIMAL
5241 * i386.h (TARGET_REP_MOVL_OPTIMAL): New macro.
5242
5243 * i386.md (negsf2_ifs, negdf2_ifs, negdf2_ifs_rex64, abssf2_ifs,
5244 absdf2_ifs, absdf2_ifs_rex64): Fix constraints.
5245 neg?f2_ifs, abs?f2_ifs splitters): Refuse memory operand; do not
5246 generate unnecesary subregs.
5247
bf97847b
JDA
52482002-12-05 John David Anglin <dave@hiauly1.hia.nrc.ca>
5249
5250 * pa32-linux.h (CANONICALIZE_FUNCPTR_FOR_COMPARE_LIBCALL): Move define.
5251 * pa.h (CANONICALIZE_FUNCPTR_FOR_COMPARE_LIBCALL): To here.
5252
1fcfaf37
DJ
52532002-12-05 Dale Johannesen <dalej@apple.com>
5254
5255 * tree.c (unsafe_for_reeval): Consider callee child of CALL_EXPR.
5256
1a823ac1
DS
52572002-12-05 Danny Smith <dannysmith@users.sourceforge.net>
5258
5259 * config/i386/cygwin.h (SUBTARGET_PROLOGUE): Replace with
5260 PROFILE_HOOK.
5261 * config/i386/mingw32.h (SUBTARGET_PROLOGUE): Don't undef.
5262
747db477
AH
52632002-12-05 Aldy Hernandez <aldyh@redhat.com>
5264
5265 * config/rs6000/spe.h (__ev_mwlufi): Remove.
5266 (__ev_mwlufia): Remove.
5267 (__ev_mwlumfaaw): Remove.
5268 (__ev_mwlusfaaw): Remove.
5269 (__ev_mwlumfanw): Remove.
5270 (__ev_mwlusfanw): Remove.
5271
94f09825
KH
52722002-12-05 Kazu Hirata <kazu@cs.umass.edu>
5273
5274 * config/h8300/h8300.md (*andorsi3_shift_8): New.
5275
1e5bdc40
KH
52762002-12-05 Kazu Hirata <kazu@cs.umass.edu>
5277
5278 * config/h8300/h8300.c (shift_alg_si): Optimize ashift:HI and
5279 lshiftrt:SI by 28, 29, and 30 bits when !TARGET_H8300.
5280 (get_shift_alg): Return optimal assembly instructions for the
5281 shifts mentioned above.
5282
4977bab6
ZW
5283Wed Dec 4 11:53:07 CET 2002 Jan Hubicka <jh@suse.cz>
5284
5285 * i386.c (ix86_expand_int_movcc): Force operand into register for QImode
5286 condtiional moves.
5287
b6fd51f6
KH
52882002-12-04 Kazu Hirata <kazu@cs.umass.edu>
5289
5290 * config/h8300/h8300.c (h8300_init_once): Do not use loop to
5291 implement ashiftrt:HI by 13 bits on H8S.
5292
9e1ab8c1
JDA
52932002-12-04 John David Anglin <dave@hiauly1.hia.nrc.ca>
5294
5295 * pa/fptr.c (__canonicalize_funcptr_for_compare): New file and function.
5296 * pa.md (canonicalize_funcptr_for_compare): Output library call to
5297 canonicalize_funcptr_for_compare_libfunc on TARGET_ELF32.
5298 * pa32-linux.h (CANONICALIZE_FUNCPTR_FOR_COMPARE_LIBCALL,
5299 CTOR_LIST_BEGIN): New defines.
5300 * pa/t-linux (LIB2FUNCS_EXTRA): New define.
5301 (fptr.c): Add make rules.
5302
16823694
GK
53032002-12-04 Geoffrey Keating <geoffk@apple.com>
5304
5305 * combine.c (combine_simplify_rtx): Add new canonicalizations.
5306 * doc/md.texi (Insn Canonicalizations): Document new
5307 canonicalizations for multiply/add combinations.
5308 * config/rs6000/rs6000.md: Add and modify floating add/multiply
5309 patterns to ensure they're used whenever they can be.
5310
5ec0b66e
KH
53112002-12-04 Kazu Hirata <kazu@cs.umass.edu>
5312
5313 * config/h8300/h8300.c: Update the comments related to shifts.
5314
7fa9ed65
CD
53152002-12-04 Chris Demetriou <cgd@broadcom.com>
5316
5317 * config/mips/mips.md (get_fnaddr): Correct length attribute.
5318
6bd6fd35
KH
53192002-12-04 Kazu Hirata <kazu@cs.umass.edu>
5320
5321 * config/h8300/h8300.md (*extzv_8_8): New.
5322 (*extzv_8_16): Likewise.
5323
c246c65d
JM
53242002-12-04 Jason Merrill <jason@redhat.com>
5325
5326 PR c++/8461, c++/8625
5327 * integrate.c (copy_decl_for_inlining): Handle explicit invisible
5328 references.
5329 * tree-inline.c (initialize_inlined_parameters): Likewise.
5330
5331 * tree.c (variably_modified_type_p): Just return an error_mark_node.
5332
ae598ab9
CD
53332002-12-04 Chris Demetriou <cgd@broadcom.com>
5334
5335 * config/mips/mips.md (get_fnaddr): Avoid placing an "la"
5336 macro instruction in a branch delay slot, to avoid assembler
5337 warnings.
5338
a9b6f1e7
EB
53392002-12-04 Eric Botcazou <ebotcazou@libertysurf.fr>
5340
5341 PR c/7622
5342 * c-semantics (genrtl_scope_stmt): Do not output inlined
5343 nested functions that contain no code.
5344
a3716585
JH
5345Wed Dec 4 15:20:54 CET 2002 Jan Hubicka <jh@suse.cz>
5346
5347 * cfgrtl.c (force_nonfallthru_and_redirect): Allow abnormal edge
5348 to be forced into nonfallthru.
5349
44924a36
JT
53502002-12-03 Jason Thorpe <thorpej@wasabisystems.com>
5351
5352 * config/t-netbsd (USER_H): Set to $(EXTRA_HEADERS).
5353
3678a93e
AH
53542002-12-03 Aldy Hernandez <aldyh@redhat.com>
5355
4977bab6 5356 * config/rs6000/spe.md (*movv1di_const0): New pattern.
3678a93e 5357
6e1be6b1
RH
53582002-12-03 Richard Henderson <rth@redhat.com>
5359
5360 * libgcc-std.ver: Inherit GCC_3.3 from GCC_3.0.
5361
c47eb51b
HPN
53622002-12-03 Hans-Peter Nilsson <hp@bitrange.com>
5363
5364 * bitmap.c (bitmap_ior_and_compl, bitmap_union_of_diff):
5365 Initialize tmp.using_obstack to 0.
5366
2cff4a6e
AS
53672002-12-03 Andreas Schwab <schwab@suse.de>
5368
5369 * config/m68k/m68k.h (EH_RETURN_DATA_REGNO): Define.
5370 (EH_RETURN_STACKADJ_RTX): Define.
5371 (EH_RETURN_HANDLER_RTX): Define.
5372 (ASM_PREFERRED_EH_DATA_FORMAT): Define.
5373 * config/m68k/m68k.c (m68k_save_reg): New function. Handle eh
5374 registers and don't save fixed registers.
5375 (m68k_output_function_prologue): Use it.
5376 (use_return_insn): Likewise.
5377 (m68k_output_function_epilogue): Likewise.
5378
491a9777
KH
53792002-12-03 Kazu Hirata <kazu@cs.umass.edu>
5380
5381 * config/h8300/h8300.c (single_one_operand): Fix a warning.
5382 (single_zero_operand): Likewise.
5383
4977bab6
ZW
53842002-12-02 Nathanael Nerode <neroden@gcc.gnu.org>
5385
5386 * Makefile.in configure configure.in dummy-conditions.c fix-header.c
5387 gcov-iov.c gen-protos.c genattr.c genattrtab.c genautomata.c
5388 gencheck.c gencodes.c genconditions.c genconfig.c genconstants.c
5389 genemit.c genextract.c genflags.c gengenrtl.c gengtype-lex.l
5390 gengtype-yacc.y gengtype.c genopinit.c genoutput.c genpeep.c
5391 genpreds.c genrecog.c gensupport.c mkconfig.sh read-rtl.c
5392 scan-decls.c scan.c config/sh/sh.h doc/configfiles.texi
5393 doc/install-old.texi: Replace hconfig.h with bconfig.h.
5394 * Makefile.in: Replace HCONFIG_H with BCONFIG_H.
5395
53962002-12-02 Andrew Pinski <pinskia@physics.uc.edu>
5397
5398 * config/rs6000/rs6000.md (ffssi): Convert to expander.
5399 (ffsdi): Likewise.
5400 (cntlzw2, cntlzd2): New patterns.
5401
54022002-12-02 H.J. Lu <hjl@gnu.org>
5403
5404 * config.gcc (mips*-*-netbsd*): Remove mips/t-netbsd.
5405 (mips*-*-linux*): Remove mips/t-linux.
5406
5407Mon Dec 2 19:26:30 CET 2002 Jan Hubicka <jh@suse.cz>
5408
5409 * i386.c (ix86_expand_int_movcc): Avoid overflow.
5410
e8a68017
KH
54112002-12-02 Kazu Hirata <kazu@cs.umass.edu>
5412
5413 * config/h8300/h8300.c (dosize): Replace argument op with
5414 sign.
5415 (h8300_output_function_prologue): Update the call to dosize.
5416 (h8300_output_function_epilogue): Likewise.
5417
834572b8
BW
54182002-12-02 Bob Wilson <bob.wilson@acm.org>
5419
5420 * config/xtensa/xtensa.h: Delete ifndefs with nothing inside them.
5421
54222002-12-02 Craig Rodrigues <rodrigc@gcc.gnu.org>
9118405f
CR
5423
5424 * configure.in: Use "missing" script to generate warning if
5425 flex or bison programs not found, instead of invoking "false".
5426 * configure: Rebuilt.
5427
4ff38cd5
JH
5428Mon Dec 2 20:28:48 CET 2002 Jan Hubicka <jh@suse.cz>
5429
5430 * unroll.c (copy_loop_body): Copy CONST_OR_PURE_CALL_P.
5431
adc72fa6
JH
5432Mon Dec 2 19:42:52 CET 2002 Jan Hubicka <jh@suse.cz>
5433
5434 * i386.c (ix86_expand_int_movcc): Avoid overflow.
5435
513f31eb
KH
54362002-12-02 Kazu Hirata <kazu@cs.umass.edu>
5437
5438 * config/h8300/h8300.c (dosize): Output r7/er7 instead of sp.
5439 (push): Likewise.
5440 (pop): Likewise.
5441 (h8300_output_function_prologue): Likewise.
5442 (h8300_output_function_epilogue): Likewise.
5443
7ffc9761
R
5444Mon Dec 2 14:43:22 2002 J"orn Rennecke <joern.rennecke@superh.com>
5445
5446 * expmed.c (store_bit_field): Use int_mode_for_mode to find
5447 corresponding mode of non-integer mode, unless it is VOIDmode.
5448
0a2a0a58
KH
54492002-12-02 Kazu Hirata <kazu@cs.umass.edu>
5450
5451 * config/h8300/h8300.md (stm_h8300s_2): New.
5452 (stm_h8300s_3): Likewise.
5453 (stm_h8300s_4): Likewise.
5454 (five define_peephole2): Likewise.
5455
28432d9f
KH
54562002-12-02 Kazu Hirata <kazu@cs.umass.edu>
5457
5458 * ra-build.c: Fix a comment typo.
5459
4977bab6
ZW
5460Sun Dec 1 16:50:47 CET 2002 Jan Hubicka <jh@suse.cz>
5461
5462 * i386.c (ix86_expand_int_movcc): fix
5463 reversed BRANCH_COST test; be curefull about infinite recursion.
5464
e651d484
KH
54652002-12-01 Kazu Hirata <kazu@cs.umass.edu>
5466
5467 * config/h8300/h8300.c (h8300_output_function_prologue):
5468 Remove variable idx.
5469 (h8300_output_function_epilogue): Likewise.
5470
558bb2c4
ZW
54712002-12-01 Zack Weinberg <zack@codesourcery.com>
5472
5473 * config/frv/xm-frv.h: Delete, unnecessary.
5474
96cc06af
KH
54752002-12-01 Kazu Hirata <kazu@cs.umass.edu>
5476
5477 * config/h8300/h8300.md: Add comments for define_peephole2.
5478
c9f8536c
MM
54792002-12-01 Mark Mitchell <mark@codesourcery.com>
5480
5481 * builtin-types.def (BT_SIZE): Use size_type_node.
5482 * builtins.c (fold_builtin): Make the builtin strlen returns a
5483 size_t, not a sizetype.
5484 * c-common.c (c_sizeof_or_alignof_type): Use size_type_node, not
5485 c_size_type_node.
5486 (c_alignof_expr): Likewise.
5487 (c_common_nodes_and_builtins): Likewise.
5488 * c-common.h (CTI_C_SIZE_TYPE): Remove.
5489 (c_size_type_node): Likewise.
5490 * c-format.c (T_ST): Use size_type_node, not c_size_type_node.
5491 * tree.h (TI_SIZE_TYPE): New enumeral.
5492 (size_type_node): Likewise.
4977bab6
ZW
5493
54942002-11-30 Zack Weinberg <zack@codesourcery.com>
5495
5496 * configure.in: Don't put ${tm_file} into host_xm_file,
5497 build_xm_file, or xm_file. Do put tm-preds.h into tm_p_file.
5498 Take location of tm-preds.h into account when calculating
5499 tm_p_file_list.
5500 * configure: Regenerate.
5501 * mkconfig.sh: No need for separate TM_DEFINES and XM_DEFINES
5502 arguments. Do not provide rtx, rtvec, tree, or GTY here.
5503 Remove special case code for tm_p.h and *config.h; add new
5504 special case code for tm.h and tconfig.h. Clean up a bit.
5505
5506 * Makefile.in (tm_file, tm_file_list): New variables set from
5507 @-substitutions.
5508 (GCONFIG_H): Deleted.
5509 (GTM_H, TM_H): New.
5510 (CONFIG_H): Is now just config.h $(host_xm_file_list).
5511 (TM_P_H): Move up with the other mkconfig.sh-generated
5512 headers; don't mention tm-preds.h explicitly.
5513 (tm.h, cs-tm.h): New rule.
5514 (cs-config.h, cs-hconfig.h, cs-tconfig.h, cs-tm_p.h): Adjust
5515 invocations of mkconfig.sh for changes to that program.
5516 (mostlyclean): Delete print-rtl1.c.
5517 (clean): Delete tm.h.
5518 Update dependencies for the files listed below.
5519
5520 * mklibgcc.in: Add 'coretypes.h $(TM_H)' to libgcc2_c_dep.
5521
5522 * coretypes.h: New file.
5523 * system.h: #define malloc to xmalloc and realloc to xrealloc
5524 when FLEX_SCANNER or YYBISON is defined, independent of the
5525 value of GCC_VERSION.
5526 * alias.c, attribs.c, bb-reorder.c, bitmap.c, builtins.c,
5527 c-aux-info.c, c-common.c, c-convert.c, c-decl.c, c-dump.c,
5528 c-errors.c, c-format.c, c-lang.c, c-lex.c, c-objc-common.c,
5529 c-opts.c, c-parse.in, c-pragma.c, c-pretty-print.c,
5530 c-semantics.c, c-typeck.c, caller-save.c, calls.c, cfg.c,
5531 cfganal.c, cfgbuild.c, cfgcleanup.c, cfglayout.c, cfgloop.c,
5532 cfgrtl.c, collect2.c, combine.c, conflict.c, convert.c,
5533 cppdefault.c, cpperror.c, cppexp.c, cppfiles.c, cpphash.c,
5534 cppinit.c, cpplex.c, cpplib.c, cppmacro.c, cppmain.c,
5535 cppspec.c, cpptrad.c, crtstuff.c, cse.c, cselib.c, dbxout.c,
5536 debug.c, df.c, diagnostic.c, doloop.c, dominance.c,
5537 dummy-conditions.c, dwarf2asm.c, dwarf2out.c, dwarfout.c,
5538 emit-rtl.c, errors.c, et-forest.c, except.c, explow.c,
5539 expmed.c, expr.c, final.c, fix-header.c, flow.c, fold-const.c,
5540 function.c, gcc.c, gccspec.c, gcov-dump.c, gcov-iov.c, gcov.c,
5541 gcse.c, gen-protos.c, genattr.c, genattrtab.c, genautomata.c,
5542 gencheck.c, gencodes.c, genconditions.c, genconfig.c,
5543 genconstants.c, genemit.c, genextract.c, genflags.c,
5544 gengenrtl.c, gengtype-lex.l, gengtype-yacc.y, gengtype.c,
5545 genopinit.c, genoutput.c, genpeep.c, genpreds.c, genrecog.c,
5546 gensupport.c, ggc-common.c, ggc-none.c, ggc-page.c,
5547 ggc-simple.c, global.c, graph.c, haifa-sched.c, hashtable.c,
5548 hooks.c, ifcvt.c, integrate.c, intl.c, jump.c, langhooks.c,
5549 lcm.c, libgcc2.c, line-map.c, lists.c, local-alloc.c, loop.c,
5550 main.c, mbchar.c, mips-tdump.c, mips-tfile.c, mkdeps.c,
5551 optabs.c, params.c, predict.c, prefix.c, print-rtl.c,
5552 print-tree.c, profile.c, protoize.c, ra-build.c,
5553 ra-colorize.c, ra-debug.c, ra-rewrite.c, ra.c, read-rtl.c,
5554 real.c, recog.c, reg-stack.c, regclass.c, regmove.c,
5555 regrename.c, reload.c, reload1.c, reorg.c, resource.c,
5556 rtl-error.c, rtl.c, rtlanal.c, sbitmap.c, scan-decls.c,
5557 scan.c, sched-deps.c, sched-ebb.c, sched-rgn.c, sched-vis.c,
5558 sdbout.c, sibcall.c, simplify-rtx.c, ssa-ccp.c, ssa-dce.c,
5559 ssa.c, stmt.c, stor-layout.c, stringpool.c, timevar.c,
5560 tlink.c, toplev.c, tracer.c, tree-dump.c, tree-inline.c,
5561 tree.c, unroll.c, varasm.c, varray.c, varray.h, vmsdbgout.c,
5562 xcoffout.c, config/darwin-c.c, config/darwin.c,
5563 config/fp-bit.c, config/alpha/alpha.c, config/alpha/vms-cc.c,
5564 config/alpha/vms-ld.c, config/arc/arc.c, config/arm/arm.c,
5565 config/arm/pe.c, config/avr/avr.c, config/c4x/c4x-c.c,
5566 config/c4x/c4x.c, config/cris/cris.c, config/d30v/d30v.c,
5567 config/dsp16xx/dsp16xx.c, config/fr30/fr30.c,
5568 config/frv/frv.c, config/h8300/h8300.c, config/i370/i370-c.c,
5569 config/i370/i370.c, config/i386/i386.c, config/i386/winnt.c,
5570 config/i960/i960-c.c, config/i960/i960.c,
5571 config/ia64/ia64-c.c, config/ia64/ia64.c, config/ip2k/ip2k.c,
5572 config/m32r/m32r.c, config/m68hc11/m68hc11.c,
5573 config/m68k/m68k.c, config/m88k/m88k.c, config/mcore/mcore.c,
5574 config/mips/irix6-libc-compat.c, config/mips/mips.c,
5575 config/mmix/mmix.c, config/mn10200/mn10200.c,
5576 config/mn10300/mn10300.c, config/ns32k/ns32k.c,
5577 config/pa/pa.c, config/pdp11/pdp11.c, config/romp/romp.c,
5578 config/rs6000/rs6000-c.c, config/rs6000/rs6000.c,
5579 config/s390/s390.c, config/sh/sh.c, config/sparc/gmon-sol2.c,
5580 config/sparc/sparc.c, config/stormy16/stormy16.c,
5581 config/v850/v850-c.c, config/v850/v850.c, config/vax/vax.c,
5582 config/xtensa/xtensa.c, objc/objc-act.c, objc/objc-lang.c:
5583 Include coretypes.h and tm.h.
5584
5585 * genattrtab.c, genconditions.c, genemit.c, genextract.c,
5586 gengenrtl.c, gengtype.c, genopinit.c, genoutput.c, genpeep.c,
5587 genrecog.c: Include coretypes.h and tm.h from the file
5588 generated by this program.
5589
5590 * unwind-dw2-fde-darwin.c, unwind-dw2-fde-glibc.c,
5591 unwind-dw2-fde.c, unwind-dw2.c, unwind-sjlj.c: Include
5592 coretypes.h and tm.h, and tsystem.h when not already included.
5593 No need to include stddef.h nor stdlib.h.
5594
5595 * fixinc/fixlib.h: Include coretypes.h and tm.h. Do not
5596 include auto-host.h or ansidecl.h/
5597 * fixinc/server.h: Do not include stdio.h, unistd.h, or fixlib.h.
5598 * fixinc/procopen.c: Include server.h after fixlib.h. Do not
5599 include auto-host.h, ansidecl.h, or system.h.
5600 * fixinc/server.c: Likewise. Also, do not include signal.h,
5601 and do not redefine volatile.
5602
5603Sat Nov 30 17:16:46 CET 2002 Jan Hubicka <jh@suse.cz>
5604
5605 * i386.md (movdf_integer): Always enable in 64bit.
5606 (movdf_nointeger): Always disable in 64bit.
5607
f6318a2b
JDA
56082002-11-30 John David Anglin <dave@hiauly1.hia.nrc.ca>
5609
5610 * cfg.c (dump_flow_info): Use max_reg_num () to determine the largest
5611 pseudo register number plus 1.
5612
4977bab6
ZW
5613Fri Nov 29 20:10:56 2002 J"orn Rennecke <joern.rennecke@superh.com>
5614
5615 * expmed.c (store_bit_field): Use int_mode_for_mode to find
5616 corresponding mode of non-integer mode, unless it is VOIDmode.
5617
2402645b
HPN
56182002-11-29 Hans-Peter Nilsson <hp@bitrange.com>
5619
5620 * cpplib.c (_cpp_test_assertion): Default *value to 0.
5621
5622 * cppexp.c (num_part_mul): Initialize result.unsignedp, to 1.
5623
8ef34c0d
UW
56242002-11-29 Ulrich Weigand <uweigand@de.ibm.com>
5625
5626 * config/s390/t-crtstuff: New target makefile fragment.
5627 * config.gcc [s390-*-linux, s390x-*-linux]: Use it.
5628
b8bbda91
KH
56292002-11-29 Kazu Hirata <kazu@cs.umass.edu>
5630
5631 * config/h8300/h8300.md (movsi_h8300hs): Change the order of
5632 alternatives to correct the length when the memory operand is
5633 either pre_dec or post_inc.
5634
d23dff51
KH
56352002-11-29 Kazu Hirata <kazu@cs.umass.edu>
5636
5637 * config/h8300/h8300.md (an anonymous pattern): Give an
5638 internal name *tst_extzv_bitqi_1_n.
5639 Accept bit_operand instead of bit_memory_operand.
5640 Do not accept bit tests with the MSB.
5641 (*tst_extzv_memqi_1_n): New.
5642
4977bab6
ZW
5643Thu Nov 28 23:56:24 CET 2002 Jan Hubicka <jh@suse.cz>
5644
5645 * i386.c (ix86_expand_int_movcc): Add copy_rtx to avoid invalid RTX
5646 sharing when operand is SUBREG.
5647
5648Thu Nov 28 08:57:26 CET 2002 Jan Hubicka <jh@suse.cz>
5649
5650 * athlon.md (athlon-decodev): New reservation unit.
5651 (athlon-direct0): New reservation.
5652 (athlon-vector): New use athlon-decodev.
5653 (athlon-double, athlon-direct): Better model.
5654 (athlon_imul_k8): Use athlon-direct0.
5655 (athlon_movlpd_load): New insn reservation.
5656
3f7211f1
KH
56572002-11-28 Kazu Hirata <kazu@cs.umass.edu>
5658
5659 * config/h8300/h8300.c (h8300_eightbit_constant_address_p):
5660 Fix a comment typo.
5661 (h8300_tiny_constant_address_p): Likewise.
5662
fcb204ce
MM
56632002-11-28 Michael Matz <matz@suse.de>
5664
5665 * doc/passes.texi: Mention the other register allocator.
5666
7957fde4
KH
56672002-11-28 Kazu Hirata <kazu@cs.umass.edu>
5668
5669 * config/h8300/h8300.md (6 new peephole2 patterns): New.
5670
17c04c5e
JJ
56712002-11-28 Jakub Jelinek <jakub@redhat.com>
5672
5673 * config.gcc (x86_64-*-linux*) [tmake_file]: Remove i386/t-crtstuff.
5674 * config/t-linux (CRTSTUFF_T_CFLAGS_S): Add $(CRTSTUFF_T_CFLAGS).
5675 * config/i386/t-linux64 (CRTSTUFF_T_CFLAGS): Define.
5676
73cc75e9
KH
56772002-11-28 Kazu Hirata <kazu@cs.umass.edu>
5678
5679 * config/h8300/h8300.c (h8300_and_costs): New.
5680 * config/h8300/h8300.h (RTX_COSTS): Use h8300_and_costs.
5681 * config/h8300/h8300-protos.h: Add a prototype for
5682 h8300_and_costs.
5683
4977bab6
ZW
5684Wed Nov 27 20:34:13 CET 2002 Jan Hubicka <jh@suse.cz>
5685
5686 * i386.c (x86_sse_partial_regs_for_cvtsd2ss): New.
5687 * i386.h (x86_sse_partial_regs_for_cvtsd2ss): Declare.
5688 (TARGET_SSE_PARTIAL_REGS_FOR_CVTSD2SS): New macro.
5689 * i386.md (truncdfsf patterns and splitters): Use
5690 TARGET_SSE_PARTIAL_REGS_FOR_CVTSD2SS
5691
0dbc3651
ZW
56922002-11-27 Zack Weinberg <zack@codesourcery.com>
5693
5694 * config/rs6000/rs6000.c (altivec_init_builtins): Make the
5695 pointer argument in the prototypes of the following builtins
5696 be (const TYPE *) rather than (TYPE *):
5697 + __builtin_altivec_ld_internal_4sf
5698 + __builtin_altivec_ld_internal_4si
5699 + __builtin_altivec_ld_internal_8hi
5700 + __builtin_altivec_ld_internal_16qi
5701 + __builtin_altivec_lvsl
5702 + __builtin_altivec_lvsr
5703 + __builtin_altivec_lvebx
5704 + __builtin_altivec_lvehx
5705 + __builtin_altivec_lvewx
5706 + __builtin_altivec_lvxl
5707 + __builtin_altivec_lvx
5708 + __builtin_altivec_dst
5709 + __builtin_altivec_dstt
5710 + __builtin_altivec_dstst
5711 + __builtin_altivec_dststt
5712
fe3f9515
KG
57132002-11-27 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
5714
5715 * except.c (default_exception_section): Move variable into the
5716 scope where it is used.
5717
4e85eada
KW
57182002-11-27 Krister Walfridsson <cato@df.lth.se>
5719
5720 * config.gcc (*-*-netbsd[2-9]*, *-*-netbsdelf[2-9]*): Test for
5721 correct version.
5722
f248423a
KH
57232002-11-27 Kazu Hirata <kazu@cs.umass.edu>
5724
5725 * config/h8300/h8300.h (OK_FOR_U): Remove extra parentheses.
5726
ae557002
KH
57272002-11-27 Kazu Hirata <kazu@cs.umass.edu>
5728
5729 * config/h8300/h8300.c (h8300_shift_costs): New.
5730 * config/h8300/h8300.h (RTX_COSTS): Use h8300_shift_costs.
5731 * config/h8300/h8300-protos.h: Add a prototype for
5732 h8300_shift_costs.
5733
c9b93e1a
JW
57342002-11-27 Jim Wilson <wilson@redhat.com>
5735
0dbc3651
ZW
5736 * config/rs6000/spe.md (spu_evsplatfi, spu_evsplati): Swap operands
5737 in output template.
c9b93e1a 5738
249e6b63
CH
57392002-11-27 Casper S. Hornstrup <chorns@users.sourceforge.net>
5740
5741 * config/i386/i386.h (DLL_IMPORT_EXPORT_PREFIX): Define.
5742 * config/i386/winnt.c (i386_pe_dllexport_name_p): Use
5743 DLL_IMPORT_EXPORT_PREFIX, not '@'.
5744 (i386_pe_dllimport_name_p): Likewise.
5745 (i386_pe_mark_dllexport): Likewise.
5746 (i386_pe_mark_dllimport): Likewise.
5747 (i386_pe_encode_section_info): Likewise.
5748 (i386_pe_strip_name_encoding): Likewise.
5749
5a5c00af
RH
57502002-11-27 Richard Henderson <rth@redhat.com>
5751
5752 * mkmap-symver.awk (BEGIN): Set sawsymbol false.
5753 (nm && NF == 3): Set sawsymbol true.
5754 (END): Exit if no symbols seen.
5755 (output): Fix map syntax error if no globals for the version.
5756
1dc46545
JH
5757Wed Nov 27 14:45:46 CET 2002 Jan Hubicka <jh@suse.cz>
5758
5759 * builtins.def (DEF_C99_BUILTIN): Fix.
5760
4977bab6
ZW
57612002-11-26 Kaz Kojima <kkojima@gcc.gnu.org>
5762
5763 * config/sh/lib1funcs.asm (FUNC, ENDFUNC0, ENDFUNC): New macros.
5764 (all): Add .size and .type information.
5765
5766Tue Nov 26 22:43:50 CET 2002 Jan Hubicka <jh@suse.cz>
5767
5768 * i386.c (ix86_expand_int_movcc): Do not emit lea for short mode on
5769 partial_reg_stall target.
5770
5771Tue Nov 26 22:27:47 CET 2002 Jan Hubicka <jh@suse.cz>
5772
5773 * i386.md (movhicc): Allow general operand.
5774 (movqicc): New expander.
5775 (movqicc_noc): New pattern.
5776 * i386.c (ix86_expand_carry_flag_compare): New function.
5777 (ix86_expand_int_movcc): Optimize harder using sbb; support more
5778 HImode conversion; support QImode conditional moves
5779
5780Tue Nov 26 16:30:59 CET 2002 Jan Hubicka <jh@suse.cz>
5781
5782 * i386.c (FAST_PROLOGUE_INSN_COUNT): Set to 20.
5783 (ix86_expand_prologue): Multiply the count by amount of registers to be
5784 pushed.
5785
5786Tue Nov 26 15:55:27 CET 2002 Jan Hubicka <jh@suse.cz>
5787
5788 * i386.c (override_options): Error about wrong -mcpu on x86-64
5789 compilation.
5790
57912002-11-26 NIIBE Yutaka <gniibe@m17n.org>
5792
5793 * config/sh/linux.h (FUNCTION_PROFILER): Implemented.
5794
5795Tue Nov 26 00:14:20 CET 2002 Jan Hubicka <jh@suse.cz>
5796
5797 * i386-protos.h (x86_extended_QIreg_mentioned_p,
5798 x86_extended_reg_mentioned_p): Declare.
5799 * i386.c (extended_reg_mentioned_1): New static function.
5800 (x86_extended_QIreg_mentioned_p,
5801 x86_extended_reg_mentioned_p): New global functions.
5802 * i386.h (REX_SSE_REGNO_P): New macro.
5803 * i386.md (prefix_rex): New attribute.
5804 (length attribute): Add rex.
5805
5154b05d
AH
58062002-11-26 Andrew Haley <aph@redhat.com>
5807
5808 * unwind-sjlj.c (_Unwind_FindEnclosingFunction): Rename
5809 from_Unwind_Find_Enclosing_Function.
5810 * unwind-dw2.c (_Unwind_FindEnclosingFunction): Likewise.
5811 * config/ia64/unwind-ia64.c (_Unwind_FindEnclosingFunction): Likewise.
5812 * libgcc-std.ver (_Unwind_FindEnclosingFunction): Rename from
5813 _Unwind_Find_Enclosing_Function, export @@GCC_3.3.
5814 * unwind.h (_Unwind_FindEnclosingFunction): Add.
0dbc3651 5815
0f942cae
HP
58162002-11-26 Hartmut Penner <hpenner@de.ibm.com>
5817
0dbc3651
ZW
5818 * config/s390/s390.c (390_output_constant_pool): Set alignment
5819 before label in 64 bit mode, behind otherwise.
0f942cae 5820
25fdb4dc
RH
58212002-11-26 Richard Henderson <rth@redhat.com>
5822
5823 * c-common.c (handle_visibility_attribute): Accept "default".
5824 * tree.h (enum symbol_visibility): New.
5825 (decl_visibility): Declare.
5826 * target.h (gcc_target.visibility): Take visibility arg as integer.
5827 * varasm.c (default_assemble_visibility): Likewise.
5828 (decl_visibility): New.
5829 (maybe_assemble_visibility): Use it.
5830 * output.h (default_assemble_visibility): Update prototype.
5831 * config/rs6000/rs6000.c (rs6000_assemble_visibility): Take
5832 visibility arg as integer.
d5c4db17 5833 * doc/extend.texi: Document default visibility.
25fdb4dc 5834
920e86b8
KH
58352002-11-26 Kazu Hirata <kazu@cs.umass.edu>
5836
5837 * config/h8300/h8300.c: Adjust spacing.
5838 * config/h8300/h8300.h: Likewise.
5839
7b1bd3c5
RH
58402002-11-26 Richard Henderson <rth@redhat.com>
5841
5842 * hooks.c (hook_bool_void_false, hook_void_tree_int,
5843 hook_void_FILEptr_constcharptr): Rename so that the return
5844 type is first.
5845 (hook_int_tree_tree_1, hook_void_tree, hook_void_tree_treeptr,
5846 hook_bool_tree_false): New.
5847 * hooks.h: Update.
5848 * langhooks-def.h: Update for renames.
5849 * target-def.h: Likewise.
5850 * tree.c (default_comp_type_attributes,
0dbc3651 5851 default_set_default_type_attributes, default_insert_attributes,
7b1bd3c5
RH
5852 default_function_attribute_inlinable_p,
5853 default_ms_bitfield_layout_p): Remove.
5854 * tree.h: Update.
5855
44571d6e
JDA
58562002-11-26 John David Anglin <dave@hiauly1.hia.nrc.ca>
5857
5858 * pa-protos.h (function_value): New prototype.
5859 * pa.c (function_value): Use a PARALLEL to return small aggregates on
5860 TARGET_64BIT.
5861 * pa.h (FUNCTION_VALUE): Use function_value.
5862 * pa.md (call_value_internal_symref, call_value_internal_reg_64bit,
5863 call_value_internal_reg, sibcall_value_internal_symref,
5864 sibcall_value_internal_symref_64bit): Remove =rf constraint on return
5865 value.
5866
084a1106
JDA
58672002-11-26 John David Anglin <dave@hiauly1.hia.nrc.ca>
5868
5869 * expr.c (gen_group_rtx, emit_group_move): New functions.
5870 * expr.h (gen_group_rtx, emit_group_move): Prototype.
5871 * function.c (expand_function_start): Use gen_group_rtx to create a
5872 PARALLEL rtx to hold the return value when the real return rtx is a
5873 PARALLEL.
5874 (expand_function_end): Use emit_group_move to move the return value
5875 from a PARALLEL to the real return registers.
5876 * rtl.h (REG_FUNCTION_VALUE_P): Allow function values to be returned
5877 in PARALLELs.
5878
5d2fe493
JT
58792002-11-26 Jason Thorpe <thorpej@wasabisystems.com>
5880
5881 * config/t-libc-ok: Fix typo.
5882
13c22933
JJ
58832002-11-26 Jakub Jelinek <jakub@redhat.com>
5884
5885 * configure.in: Move AC_CANONICAL_SYSTEM and AC_ARG_PROGRAM back
5886 before AC_PROG_CC.
5887 * configure: Rebuilt.
5888
5326cd3d
NS
58892002-11-26 Nathan Sidwell <nathan@codesourcery.com>
5890
5891 * c-decl.c: (start_struct): Commonize flag setting.
5892
647d340d
JT
58932002-11-26 Jason Thorpe <thorpej@wasabisystems.com>
5894
5895 * config/rs6000/rs6000.h (RS6000_CPU_CPP_ENDIAN_BUILTINS): New.
5896 * config/rs6000/rs6000-c.c (rs6000_cpu_cpp_builtins): Use
0dbc3651 5897 RS6000_CPU_CPP_ENDIAN_BUILTINS.
647d340d
JT
5898 * config/rs6000/netbsd.h (RS6000_CPU_CPP_ENDIAN_BUILTINS): Redefine.
5899
29742ba4
HP
59002002-11-26 Hartmut Penner <hpenner@de.ibm.com>
5901
5902 * config/s390/s390.md (literal_pool_64, literal_pool_31 ): New
5903 insns.
5904 * config/s390/s390.c (struct machine_function): Introduction of
5905 struct machine_function.
0412a4d4
HP
5906 (s390_output_symbolic_const): Use of cfun.
5907 (s390_optimize_prolog): Likewise.
5908 (s390_fixup_clobbered_return_reg): Likewise.
5909 (s390_frame_info): Likewise.
5910 (s390_emit_prologue, s390_emit_epilogue): Likewise.
5911 (s390_init_machine_status): New function.
5912 (override_options): call s390_init_machine_status.
0dbc3651 5913 * config/s390/s390-protos.h (s390_output_constant_pool): Changed
29742ba4 5914 prototype.
0dbc3651 5915
f4111593
JJ
59162002-11-26 Jakub Jelinek <jakub@redhat.com>
5917
5918 * varasm.c (output_constant_pool): For pool constants in mergeable
5919 section ensure each constant is padded to multiple of entity size.
5920
96d0f4dc
JJ
59212002-11-26 Jakub Jelinek <jakub@redhat.com>
5922
5923 * varasm.c (default_exception_section): Move to...
5924 * except.c (default_exception_section): ... here. Make
5925 .gcc_except_table read-only if it is not expected to have any
5926 dynamic relocations and linker handles it.
5927 * dwarf2out.c (default_eh_frame_section): Make .eh_frame read-only
5928 if it is not expected to have any dynamic relocations and linker
5929 handles it.
5930 * configure.in (HAVE_LD_RO_RW_SECTION_MIXING): Check what ld does
5931 when linking read-only and read-write sections together.
5932 * configure, config.in: Rebuilt.
5933 * crtstuff.c (EH_FRAME_SECTION_CONST): Define.
5934 (__EH_FRAME_BEGIN__, __FRAME_END__): Add it.
5935
4977bab6
ZW
5936Mon Nov 25 18:32:37 CET 2002 Jan Hubicka <jh@suse.cz>
5937
5938 * i386.md (pushsf_rex64): Fix typo.
5939
020a7b12
AH
59402002-11-25 Aldy Hernandez <aldyh@redhat.com>
5941
249e6b63
CH
5942 * config/rs6000/spe.h (__ev_create_sfix32_fs): Change macro into
5943 new function.
5944 (__ev_create_ufix32_fs): Same.
5945 (__ev_get_sfix32_fs_internal): New.
5946 (__ev_get_sfix32_fs): Define to use function.
5947 (__ev_get_ufix32_fs_internal): New.
5948 (__ev_get_ufix32_fs): Define to use function.
5949 (__ev_get_upper_ufix32_fs): Call __ev_get_ufix32_fs.
5950 (__ev_get_lower_ufix32_fs): Same.
5951 (__ev_get_upper_sfix32_fs): Call __ev_get_sfix32_fs.
5952 (__ev_get_lower_sfix32_fs): Same.
5953 (__ev_set_sfix32_fs_internal): New.
5954 (__ev_set_ufix32_fs_internal): New.
5955 (__ev_set_sfix32_fs): Call __ev_set_sfix32_fs_internal.
5956 (__ev_set_ufix32_fs): Call __ev_set_ufix32_fs_internal.
5957 (__ev_set_upper_sfix32_fs): Call function.
5958 (__ev_set_lower_sfix32_fs): Same.
5959 (__ev_set_upper_ufix32_fs): Same.
5960 (__ev_set_lower_ufix32_fs): Same.
020a7b12 5961
d2dff06b
DR
59622002-11-25 Douglas B Rupp <rupp@gnat.com>
5963
5964 * gcc.c (do_spec_1): Reset delete_this_arg to zero.
5965
32f0ffb3
JT
59662002-11-25 Jason Thorpe <thorpej@wasabisystems.com>
5967
5968 * config/elfos.h (HANDLE_SYSV_PRAGMA): Define as 1.
5969 * config/interix.h (HANDLE_SYSV_PRAGMA): Likewise.
5970 * config/linux-aout.h (HANDLE_SYSV_PRAGMA): Likewise.
5971 * config/lynx-ng.h (HANDLE_SYSV_PRAGMA): Likewise.
5972 * config/lynx.h (HANDLE_SYSV_PRAGMA): Likewise.
5973 * config/netbsd.h (HANDLE_SYSV_PRAGMA): Likewise.
5974 * config/openbsd.h (HANDLE_SYSV_PRAGMA: Likewise.
5975 * config/alpha/elf.h (HANDLE_SYSV_PRAGMA): Likewise.
5976 * config/arm/netbsd.h (HANDLE_SYSV_PRAGMA): Likewise.
5977 * config/cris/aout.h (HANDLE_SYSV_PRAGMA): Likewise.
5978 * config/d30v/d30v.h (HANDLE_SYSV_PRAGMA): Likewise.
5979 * config/frv/frv.h (HANDLE_SYSV_PRAGMA): Likewise.
5980 * config/i386/djgpp.h (HANDLE_SYSV_PRAGMA): Likewise.
5981 * config/i386/i386-interix.h (HANDLE_SYSV_PRAGMA): Likewise.
5982 * config/i386/vxi386.h (HANDLE_SYSV_PRAGMA): Likewise.
5983 * config/ia64/ia64.h (HANDLE_SYSV_PRAGMA): Likewise.
5984 * config/m88k/m88k.h (HANDLE_SYSV_PRAGMA): Likewise.
5985 * config/mmix/mmix.h (HANDLE_SYSV_PRAGMA): Likewise.
5986 * config/rs6000/aix.h (HANDLE_SYSV_PRAGMA): Likewise.
5987 * config/rs6000/darwin.h (HANDLE_SYSV_PRAGMA): Likewise.
5988 * config/sparc/linux-aout.h (HANDLE_SYSV_PRAGMA): Likewise.
5989 * config/sparc/vxsparc64.h (HANDLE_SYSV_PRAGMA): Likewise.
5990 * config/stormy16/stormy16.h (HANDLE_SYSV_PRAGMA): Likewise.
5991 * config/alpha/osf.h (HANDLE_SYSV_PRAGMA): Don't undef before
5992 defining.
5993 * config/i386/sco5.h (HANDLE_SYSV_PRAGMA): Likewise.
5994 * config/mips/iris5.h (HANDLE_SYSV_PRAGMA): Likewise.
5995
160f9a4c
DP
59962002-11-25 Dave Pitts <dpitts@cozx.com>
5997
5998 * gcc/fixinc/mkfixinc.sh: add i370-*-openedition to bypass fixinc list
5999
3c0f5389
KH
60002002-11-25 Kazu Hirata <kazu@cs.umass.edu>
6001
6002 * config/h8300/h8300.md (an anonymous pattern): New.
6003
83bbd9b6
RH
60042002-11-25 Richard Henderson <rth@redhat.com>
6005
6006 * alias.c (find_base_value): Use new_reg_base_value if it's live.
6007 (copying_arguments): Make boolean.
6008
7c64a860
JT
60092002-11-25 Jason Thorpe <thorpej@wasabisystems.com>
6010
6011 * gcc.c (static_spec_functions): Add if-exists-else spec
6012 function.
6013 (if_exists_else_spec_function): New function.
6014 * doc/invoke.texi: Document the if-exists-else spec function.
6015
6016 * config/netbsd-elf.h (NETBSD_STARTFILE_SPEC): For -static, use
6017 "%:if-exists-else(crtbeginT%O%s crtbegin%O%s)".
6018
a4967b8d
JT
60192002-11-25 Jason Thorpe <thorpej@wasabisystems.com>
6020
6021 * config.gcc (powerpc-*-netbsd*): Replace "svr4.h" with
6022 "netbsd.h netbsd-elf.h" in tm_file. Set tmake_file to
6023 "${tmake_file} rs6000/t-netbsd".
6024 * config/rs6000/netbsd.h: Rewrite.
6025 * config/rs6000/t-netbsd: New file.
6026
a91dce31
KH
60272002-11-25 Kazu Hirata <kazu@cs.umass.edu>
6028
6029 * config/h8300/h8300.md (an anonymous pattern): Relax the
6030 condition for the pattern.
6031
fe29a4ea
AH
60322002-11-25 Aldy Hernandez <aldyh@redhat.com>
6033
6034 * config/rs6000/rs6000.h (enum rs6000_builtins): Remove evmwlssf,
6035 evmwlsmf, evmwlssfa, evmwlsmfa, evmwlssfaaw, evmwlsmfaaw,
6036 evmwlssfanw, evmwlsmfanw.
6037
6038 * config/rs6000/rs6000.c (bdesc_2arg): Same.
6039
6040 * config/rs6000/spe.md: Same for patterns.
6041
b77f3744
CE
60422002-11-25 Christian Ehrhardt <ehrhardt@mathematik.uni-ulm.de>
6043
6044 PR c/8639
6045 * fold-const.c (extract_muldiv): Don't propagate division unless
6046 both arguments are multiples of C.
6047
5dafd282
AH
60482002-11-25 Andrew Haley <aph@redhat.com>
6049
249e6b63
CH
6050 * libgcc-std.ver (_Unwind_Find_Enclosing_Function): Add.
6051 * config/ia64/unwind-ia64.c (_Unwind_Find_Enclosing_Function): New.
6052 * unwind-sjlj.c (_Unwind_Find_Enclosing_Function): Likewise.
6053 * unwind-dw2.c (_Unwind_Find_Enclosing_Function): Likewise.
5dafd282 6054
4977bab6
ZW
6055Sun Nov 24 10:38:04 CET 2002 Jan Hubicka <jh@suse.cz>
6056
6057 * i386.c (x86_use_ffreep): New global variable.
6058 * i386.h (x86_use_frfeep): Declare
6059 (TARGET_USE_FFREEP): New macro
6060 * i386.md (movs?f*): Use freep when asked for.
6061 (push?f): Remove dead code.
6062
92d4b8a0
KH
60632002-11-24 Kazu Hirata <kazu@cs.umass.edu>
6064
6065 * config/h8300/h8300.c (h8300_init_once): Fix a typo in the
6066 target help message.
6067
1169f9e0
JT
60682002-11-24 Jason Thorpe <thorpej@wasabisystems.com>
6069
6070 * config.gcc (*-*-netbsd*1.[7-9]*, *-*-netbsd*[2-9]*): Set
6071 extra_parts to "crtbegin.o crtend.o crtbeginS.o crtendS.o
6072 crtbeginT.o".
6073 (arm*-*-netbsd*, i[34567]86-*-netbsd*, m68k*-*-netbsd*)
6074 (ns32k-*-netbsd*, sparc-*-netbsd*, vax-*-netbsd*): Set extra_parts
6075 to "" for a.out configurations.
6076 * config/t-netbsd (CRTSTUFF_T_CFLAGS): Set to "-fPIC".
6077
adde288a
JT
60782002-11-24 Jason Thorpe <thorpej@wasabisystems.com>
6079
6080 * config/alpha/netbsd.h (CPP_SUBTARGET_SPEC): Just use
0dbc3651 6081 NETBSD_CPP_SPEC directly.
adde288a
JT
6082 (SUBTARGET_EXTRA_SPECS): Remove netbsd_cpp_spec. Add
6083 netbsd_endfile_spec.
6084 (ENDFILE_SPEC): Use %(netbsd_endfile_spec).
6085
1ebe8c03
JT
60862002-11-24 Jason Thorpe <thorpej@wasabisystems.com>
6087
6088 * config/netbsd-elf.h (STARTFILE_SPEC): Rename to
6089 NETBSD_STARTFILE_SPEC.
6090 (STARTFILE_SPEC): Redefine in terms of NETBSD_STARTFILE_SPEC.
6091 (ENDFILE_SPEC): Likewise.
6092 * config/netbsd.h (LIB_SPEC, LIBGCC_SPEC): Likewise.
6093
bdabc150
AS
60942002-11-24 Andreas Schwab <schwab@suse.de>
6095
523cb499
AS
6096 * Makefile.in (install-driver): Remove versioned link before
6097 trying to create it.
6098
bdabc150
AS
6099 * config/m68k/m68k.c: Fix typo in last change defining
6100 TARGET_ASM_CAN_OUTPUT_MI_THUNK.
6101
4977bab6
ZW
61022002-11-23 H.J. Lu <hjl@gnu.org>
6103
6104 * aclocal.m4: Include ../config/accross.m4.
6105 (gcc_AC_COMPILE_CHECK_SIZEOF): Removed.
6106 (gcc_AC_C_COMPILE_ENDIAN): Removed.
6107 (gcc_AC_C_FLOAT_FORMAT): Check $ac_cv_c_bigendian
6108 instead of $ac_cv_c_compile_endian.
6109
6110 * configure.in: Replace gcc_AC_COMPILE_CHECK_SIZEOF with
6111 AC_COMPILE_CHECK_SIZEOF.
6112 Replace gcc_AC_C_COMPILE_ENDIAN with AC_C_BIGENDIAN_CROSS.
6113 * configure: Rebuild.
6114
56b8e164
KH
61152002-11-23 Kazu Hirata <kazu@cs.umass.edu>
6116
6117 * config/h8300/h8300.c (print_operand): Update the use of
6118 h8300_tiny_constant_address_p.
6119 (h8300_adjust_insn_length): Likewise.
6120 (h8300_tiny_constant_address_p): Check if the given rtx is a
6121 variable declared with __attribute__ ((tiny_data)).
6122
2bb74773
DJ
61232002-11-22 Dale Johannesen <dalej@apple.com>
6124
249e6b63 6125 * toplev.c (rest_of_compilation): Fix comments.
2bb74773 6126
199cbacc
GK
61272002-11-22 Geoffrey Keating <geoffk@apple.com>
6128
6129 * aclocal.m4 (ac_cv_func_mmap_dev_zero): Darwin does not
6130 allow mmap from /dev/zero. Don't make decisions for the host
6131 based on presence or absence of /dev/zero on the build machine.
6132 (ac_cv_func_mmap_anon): Darwin does have working MMAP_ANON.
6133 (AC_FUNC_MMAP_FILE): Darwin does have mmap of a file.
6134 * configure: Regenerate.
6135
42766f8d
DJ
61362002-11-22 Daniel Jacobowitz <drow@mvista.com>
6137
6138 * gcc.c (make_relative_prefix, split_directories)
6139 (free_split_directories): Removed.
6140
80486e06
DJ
61412002-11-22 Daniel Jacobowitz <drow@mvista.com>
6142
6143 * configure.in: Set insn=nop for DWARF-2 tests on ARM.
6144 * configure: Regenerated.
6145
41c3eb5d
KH
61462002-11-22 Kazu Hirata <kazu@cs.umass.edu>
6147
6148 * config/h8300/h8300.c (compute_a_shift_length): Fix the insn
6149 length computation when xor.l is output.
6150
4977bab6
ZW
61512002-11-21 Douglas B Rupp <rupp@gnat.com>
6152
6153 * alpha.md (movstrdi, clrstrdi): New VMS patterns.
6154 (call_vms_1, call_value_vms_1): Cleanup syntax.
6155
6156Thu Nov 21 19:20:27 CET 2002 Jan Hubicka <jh@suse.cz>
6157
6158 * athlon.md (define_atuomaton): Add athlon_load.
6159 (athlon-double): New reservation.
6160 (athlon-ieu0): New CPU unit.
6161 (athlon-load?): Use athlon_load automaton.
6162 (*_k8 reservations): New.
6163 (other insn revervations): Activate for K8.
6164
6165Thu Nov 21 15:07:42 CET 2002 Jan Hubicka <jh@suse.cz>
6166
6167 * cfgrtl.c (verify_flow_info): Accept EDGE_CAN_FALLTHRU flag.
6168
57de2c8f
JW
61692002-11-21 Jim Wilson <wilson@redhat.com>
6170
6171 * config/rs6000/rs6000.c (function_arg): Set inner mode of SPE
6172 vectors to SI.
6173
58db834b
BW
61742002-11-21 Bob Wilson <bob.wilson@acm.org>
6175
6176 * config/xtensa/xtensa-protos.h (xtensa_copy_incoming_a7): Declare.
6177 * config/xtensa/xtensa.c (struct machine_function): Add
6178 incoming_a7_copied flag.
6179 (xtensa_copy_incoming_a7): Define.
6180 (xtensa_emit_move_sequence): Use xtensa_copy_incoming_a7.
6181 * config/xtensa/xtensa.md (movdi, movsf, movdf): Ditto.
6182
c05dbe81
JH
6183Thu Nov 21 23:52:04 CET 2002 Jan Hubicka <jH@suse.cz>
6184
6185 * i386-protos.h (x86_64_sign_extended_value): Fix prototype.
6186 * i386.c (x86_64_general_operand, x86_64_szext_general_operand,
0dbc3651 6187 x86_64_nonmemory_operand, x86_64_movabs_operand,
c05dbe81
JH
6188 x86_64_szext_nonmemory_operand, x86_64_immediate_operand,
6189 ix86_expand_int_movcc): Update call of x86_64_sign_extended_value.
6190 (local_symbolic_operand): Do not care the 64bit limits.
6191 (x86_64_sign_extended_value): Remove allow_rip support.
6192 (legitimate_pic_address_disp_p): Handle all cases allowed
6193 with RIP addressing.
6194 (legitimate_address_p): Use legitimate_pic_address_disp_p for PIC.
6195 (legitimize_pic_address): Reorganize.
6196 * i386.h (EXTRA_CONSTRAINT): Update call of x86_64_sign_extended_value.
6197
ff3afb56
JT
61982002-11-21 Jason Thorpe <thorpej@wasabisystems.com>
6199
6200 * config.gcc (arm*-*-netbsdelf*): Enable configuration.
6201 * config/arm/netbsd-elf.h: New file.
6202
57c21a42
JT
62032002-11-21 Jason Thorpe <thorpej@wasabisystems.com>
6204
6205 * config/arm/elf.h (SUBTARGET_EXTRA_SPECS): Add
6206 subtarget_asm_float_spec.
6207 (SUBTARGET_ASM_FLOAT_SPEC): Define, moving the
6208 defaults from...
6209 (ASM_SPEC): ...here. Use subtarget_asm_float_spec.
6210
3d5ee65b
NC
62112002-11-21 Nick Clifton <nickc@redhat.com>
6212
6213 * config/fr30/fr30.md (movsf_constant_store): Move code to
6214 detect 0.0 into fr30.c.
6215 * config/fr30/fr30-protos.h (fr30_const_double_is_zero):
6216 Prototype.
6217 * config/fr30/fr30.c (fr30_const_double_is_zero): New
6218 function. Return true if the rtx is 0.0.
6219
4d938a09
JT
62202002-11-21 Jason Thorpe <thorpej@wasabisystems.com>
6221
6222 * config/arm/elf.h (ASM_SPEC, LINK_SPEC): Pass -EL
6223 if -mlittle-endian is specified.
6224
1dda7ee4
RE
62252002-11-21 Richard Earnshaw <rearnsha@arm.com>
6226
6227 PR optimization/2903
6228 * arm.md (anddi_notzesidi_di): Operand 2 is inverted not operand 1.
6229 (anddi_notsesidi_di): Likewise.
6230
7c143ed2
KH
62312002-11-21 Kazu Hirata <kazu@cs.umass.edu>
6232
6233 * config/h8300/h8300.c (print_operand): Use
6234 h8300_eightbit_constant_address_p and
6235 h8300_tiny_constant_address_p.
6236 (h8300_adjust_insn_length): Likewise.
6237 * config/h8300/h8300.h (EIGHTBIT_CONSTANT_ADDRESS_P): Remove.
6238 (TINY_CONSTANT_ADDRESS_P): Likewise.
6239 (OK_FOR_U): Use eightbit_constant_address_p.
6240
b5798b2a
UW
62412002-11-21 Ulrich Weigand <uweigand@de.ibm.com>
6242
6243 * config/s390/libgcc-libc.ver: Add multilib support.
6244 * config/s390/linux.h (MULTILIB_DEFAULT): Define.
0dbc3651
ZW
6245 * config/s390/t-linux64 (MULTILIB_OPTIONS, MULTILIB_DIRNAMES,
6246 MULTILIB_OSDIRNAMES, LIBGCC, INSTALL_LIBGCC,
b5798b2a
UW
6247 EXTRA_MULTILIB_PARTS): Define.
6248
c231c91e
RE
62492002-11-21 Richard Earnshaw <rearnsha@arm.com>
6250
6251 * arm.c (arm_get_frame_size): A leaf function does not need its
6252 stack padding to an aligned boundary if it has no frame.
6253 (thumb_get_frame_size): Likewise.
6254
4977bab6
ZW
6255Wed Nov 20 22:25:53 CET 2002 Jan Hubicka <jh@suse.cz>
6256
6257 * x86-64.h (MCOUNT_NAME): Fix typo in my previous patch.
6258 (override_options): Likewise.
6259
6260Wed Nov 20 19:07:17 CET 2002 Jan Hubicka <jh@suse.cz>
6261
6262 * config.gcc: Add k8 target alias support
6263 * i386.c (_cost): Declare costs for various variants of divides and
6264 multiplies.
6265 (k8_cost): New.
6266 (m_K8, m_ATHLON_K8): New macros.
6267 (x86_use_leave, x86_push_memory, x86_movx, x86_unroll_strlen,
6268 x86_cmove, x86_3dnow_a, x86_deep_branch, x86_use_fiop,
6269 x86_promote_QImode, x86_sub_esp_?, x86_add_esp_?,
6270 x86_integer_DFmode_moves, x86_partial_reg_dependency,
6271 x86_memory_mismatch_stall, x86_accumulate_outgoing_args,
6272 x86_prologue_using_move, x86_epilogue_using_move,
6273 x86_arch_always_fancy_math_387, x86_sse_partial_regs,
6274 x86_sse_typeless_stores): Set for K8
6275 (override_options): Add k8 support; fix athlon alignment;
6276 complain about non-x86-64 capable CPU being used in x86-64 compilation.
6277 (ix86_issue_rate): Set for K8.
6278 (ix86_adjust_cost, ia32_use_dfa_pipeline_interface,
6279 x86_machine_dependent_reorg): Handle K8 like
6280 * i386.h
6281 (x86_costs): Change mult_init and divide into array.
6282 (TARGET_K8, TARGET_ATHLON): New macros.
6283 (MODE_INDEX): New macro.
6284 (RTX_COST): Use new costs.
6285 (TARGET_CPU_CPP_BUILTINS): Define __k8__ and __tune_k8__.
6286 (TARGET_CPU_DEFAULT_NAMES): Add k8
6287 (TARGET_CPU_DEFAULT_k8): New constant
6288 (enum processor_type): Add PROCESSOR_K8.
6289 * i386.md (cpu attribute): Add k8.
6290
6291 * invoke.texi: Document -march=k8.
6292
6293 * i386.md (type attribute): Add leave
6294 (mode attribute): Remove unknownfp.
6295 (length_immediate, modrm, memory attributes): Handle leave correctly.
6296 (fp comparison patterns): Determine FP mode.
6297 (leave, leave_rex64): Remove special cases.
6298 * ppro.md (ppro_uops, ppro_p2): Add leave
6299 * pentiun.md (pent_pop): Handle leave too.
6300 * k6.md (k6_load): Handle leave.
6301 * athlon.md (athlon_leave, athlon_pop): Fix.
6302 (athlon_decode): Handle leave.
6303
27e58a70
SE
63042002-11-20 Steve Ellcey <sje@cup.hp.com>
6305
6306 * emit-rtl.c (gen_reg_rtx): Simplify mapping of Complex type
6307 to component type using GET_MODE_INNER.
6308 * expr.c (emit_move_insn_1): Ditto.
6309 * optabs.c (expand_binop): Ditto.
6310 (expand_unop): Ditto.
6311 (expand_complex_abs): Ditto.
6312
964b104a
DR
63132002-11-20 Douglas B Rupp <rupp@gnat.com>
6314
6315 * hwint.h (HAVE___INT64): Fix typo (was HAVE__INT64).
6316
3d4b192a
DD
63172002-11-20 DJ Delorie <dj@redhat.com>
6318
6319 * config/stormy16/stormy16.c (s16builtins,
6320 xstormy16_init_builtins, xstormy16_expand_builtin): New.
6321 * config/stormy16/stormy16.md (divmodhi4, sdivlh, udivlh): New.
6322
414d23ae
HPN
63232002-11-20 Hans-Peter Nilsson <hp@bitrange.com>
6324
6325 * Makefile.in (RUN_GEN, VALGRIND_DRIVER_DEFINES): New variables.
6326 (DRIVER_DEFINES): Add $(VALGRIND_DRIVER_DEFINES).
6327 (executing gencheck, genconfigs, genconditions, genflags,
6328 gencodes, genconstants, genemit, genrecog, genopinit, genextract,
6329 genpeep, genattr, genattrtab, genoutput, gengenrtl, genpreds,
6330 gengtype, genprotos): Prepend $(RUN_GEN).
6331 * configure.in: Move host compiler tests before --enable-checking
6332 tests.
6333 (--enable-checking=valgrind): New.
6334 * config.in, configure: Regenerate.
6335 * cppfiles.c [!ENABLE_VALGRIND_CHECKING] (VALGRIND_DISCARD):
6336 Define as empty.
6337 (read_include_file): When doing the mmap+1 trick,
6338 valgrind-annotate the byte after the mmap:ed area as readable.
6339 (purge_cache): Remove above annotation.
6340 * gcc.c (execute) [ENABLE_VALGRIND_CHECKING]: Arrange to prepend
6341 VALGRIND_PATH -q to each command.
6342
9a0a7d5d
HPN
6343 * ggc-common.c [!ENABLE_VALGRIND_CHECKING] (VALGRIND_DISCARD):
6344 Define as empty.
6345 (ggc_realloc): Update valgrind annotations.
6346 * ggc-page.c [!ENABLE_VALGRIND_CHECKING] (VALGRIND_DISCARD):
6347 Define as empty.
c14bc6db 6348 (alloc_anon, free_page, ggc_alloc, poison_pages): Add machinery to
9a0a7d5d
HPN
6349 valgrind-annotate memory.
6350
3ba2436a
UW
63512002-11-20 Ulrich Weigand <uweigand@de.ibm.com>
6352
6353 * recog.c (constrain_operands): Prefer exact match over reloadable
6354 EXTRA_MEMORY_CONSTRAINT or EXTRA_ADDRESS_CONSTRAINT.
6355
6356 * reload.c (find_reloads): Always reload EXTRA_ADDRESS_CONSTRAINT
6357 operands in Pmode.
6358
a9b6f1e7 63592002-11-20 Eric Botcazou <ebotcazou@libertysurf.fr>
02a362d9
EB
6360
6361 PR c/8518
6362 * c-decl.c (duplicate_decls): Outline the second definition
6363 of an extern inline function in all cases.
6364
5354730b
RS
63652002-11-20 Richard Sandiford <rsandifo@redhat.com>
6366
6367 * stor-layout.c (place_field): Update rli->offset as well as
6368 rli->bitpos.
6369
5720520f
RS
63702002-11-20 Richard Sandiford <rsandifo@redhat.com>
6371
6372 * sched-deps.c (sched_analyze): Check HARD_REGNO_CALL_PART_CLOBBERED.
6373
4392ebd3
RS
63742002-11-20 Richard Sandiford <rsandifo@redhat.com>
6375
6376 * config/sh/sh.md (udivsi3): Don't put udivsi3_i4_media instructions
6377 into a libcall block.
6378 (divsi3): Likewise divsi3_i4_media.
6379
3748bd9e
RS
63802002-11-20 Richard Sandiford <rsandifo@redhat.com>
6381
6382 * global.c (find_reg): Check HARD_REGNO_NREGS before kicking
6383 out another register.
6384
bc02f8d3
JJ
63852002-11-20 Jakub Jelinek <jakub@redhat.com>
6386
6387 * combine.c (force_to_mode): Only replace with (not Y) if all bits in fuller_mask
6388 (not just mask) are set in C.
6389
4977bab6
ZW
63902002-11-19 Steven Bosscher <steven.bosscher@usafa.af.mil>
6391
6392 * config/mips/vr.h (DRIVER_SELF_SPECS): Change %{<mgp32} to %<mgp32.
6393
63942002-11-19 Zdenek Dvorak <rakdver@atrey.karlin.mff.cuni.cz>
6395
6396 * profile.c (index_counts_file): Fix obvious mistake.
6397
63982002-11-19 Zdenek Dvorak <rakdver@atrey.karlin.mff.cuni.cz>
6399
6400 * Makefile.in (profile.o): Add hashtab.h dependency.
6401 * gcov-io.h (GCOV_SUMMARY_LENGTH): New.
6402 * profile.c: Include hashtab.h.
6403 (htab_counts_index_hash, htab_counts_index_eq, htab_counts_index_del,
6404 cleanup_counts_index, index_counts_file, struct section_reference,
6405 struct da_index_entry, counts_file_name, counts_file_index): New.
6406 (get_exec_counts, init_branch_prob): Modified.
6407
64082002-11-19 Kaz Kojima <kkojima@gcc.gnu.org>
6409
6410 * config.gcc (sh*-*-linux*): Add t-slibgcc-elf-ver and t-linux
6411 to tmake_file. Remove setting gas and gnu_ld here.
6412 * config/sh/libgcc-glibc.ver: New file.
6413 * config/sh/t-linux (EXTRA_MULTILIB_PARTS): Add crtbeginT.o.
6414 (SHLIB_MAPFILES): New.
6415 * config/sh/linux.h (MD_EXEC_PREFIX): Undefine.
6416 (MD_STARTFILE_PREFIX): Likewise.
6417 (HANDLE_PRAGMA_PACK_PACK_PUSH_POP): Define.
6418 (DWARF2_UNWIND_INFO): Redefine.
6419 (ASM_PREFERRED_EH_DATA_FORMAT): Define.
6420 (LINK_EH_SPEC): Redefine.
6421 (MD_FALLBACK_FRAME_STATE_FOR): Define except for SH-media.
6422 (SH_FALLBACK_FRAME_FLOAT_STATE): Define.
6423 (SH_DWARF_FRAME_GP0, SH_DWARF_FRAME_FP0, SH_DWARF_FRAME_XD0,
6424 SH_DWARF_FRAME_BT0, SH_DWARF_FRAME_PR, SH_DWARF_FRAME_PR_MEDIA,
6425 SH_DWARF_FRAME_GBR, SH_DWARF_FRAME_MACH, SH_DWARF_FRAME_MACL,
6426 SH_DWARF_FRAME_PC, SH_DWARF_FRAME_SR, SH_DWARF_FRAME_FPUL,
6427 SH_DWARF_FRAME_FPSCR): Likewise.
6428 * config/sh/sh-protos.h (sh_set_return_address): Declare.
6429 * config/sh/sh.c (calc_live_regs): Count EH_RETURN_DATA_REGNO
6430 registers if the current function calls EH return.
6431 (sh_expand_epilogue): Handle EH stack adjustments.
6432 (sh_set_return_address): New function.
6433 * config/sh/sh.h (SH_DBX_REGISTER_NUMBER): Handle PR_MEDIA_REG.
6434 Don't abort even if the number is mapped to -1.
6435 (EH_RETURN_DATA_REGNO): Define.
6436 (EH_RETURN_STACKADJ_RTX): Define.
6437 * config/sh/sh.md (UNSPEC_EH_RETURN): New.
6438 (eh_return): New pattern.
6439 (eh_set_ra_di, eh_set_ra_si): Likewise.
6440 Add splitter to perform EH return after reload.
6441
6442Tue Nov 19 12:52:07 2002 J"orn Rennecke <joern.rennecke@superh.com>
6443
6444 * stor-layout.c (excess_unit_span): New function.
6445 (place_field): Use it.
6446
64472002-11-19 Andreas Schwab <schwab@suse.de>
6448
6449 * unwind.h (_Unwind_GetTextRelBase): Revert last change, this is
6450 not valid in C++.
6451
64522002-11-19 Nathanael Nerode <neroden@gcc.gnu.org>
6453
6454 * configure.in, Makefile.in: Correct BUILD/HOST confusion.
6455 * configure: Regenerate.
6456
6457Tue Nov 19 00:11:44 CET 2002 Jan Hubicka <jh@suse.cz>
6458
6459 * convert.c (strip_float_extensions): New function.
6460 (convert_to_real): Optimize some cases.
6461
3bdcef4d
AJ
64622002-11-19 Andreas Jaeger <aj@suse.de>
6463
6464 * loop.c (record_giv): Initialize not_replaceable.
6465 (check_final_value): Likewise.
6466
ec5b0c68
KH
64672002-11-19 Kazu Hirata <kazu@cs.umass.edu>
6468
6469 * config/h8300/h8300.c (h8300_init_once): Replace 1 with
6470 MASK_H8300S.
6471
64722002-11-19 Vijay L. Khuspe <vijayk1@kpit.com>
39ba95b5
VK
6473
6474 * config/h8300/h8300.c (h8300_init_once): Allow -mn switch
6475 only if -mh or -ms present.
6476 (h8300_eightbit_constant_address_p): Support the normal mode.
6477 (h8300_tiny_constant_address_p): Likewise.
6478 * config/h8300/h8300.h (TARGET_NORMAL_MODE): New.
6479 (POINTER_SIZE): Add 16 bit pointer for the normal mode.
6480 (Pmode): Evaluate to HImode for the normal mode.
6481 (SIZE_TYPE): Evaluate to unsigned int for normal mode.
6482 (PTRDIFF_TYPE): Evaluate to int for the normal mode.
6483 (ASM_WORD_OP): Evaluate to word for the normal mode.
6484 * config/h8300/h8300.md (tablejump_normal_mode): New.
6485 (indirect_jump_normal_mode): New.
6486 * config/h8300/t-h8300 (MULTILIB_OPTIONS): Pass -mn option to
6487 directory.
6488 (MULTILIB_DIRNAMES): Create target dependent directory
6489 'normal'.
249e6b63 6490 (MULTILIB_EXCEPTIONS): Don't turn on -mn on H8/300.
39ba95b5
VK
6491 * doc/invoke.texi (gccoptlist): Describe the new switch -mn.
6492
efcc7037
JH
6493Tue Nov 19 23:50:56 CET 2002 Jan Hubicka <jh@suse.cz>
6494
6495 * i386.md (length_immediate): Do not refer to insn address.
6496 (jcc*, jmp patterns): Compute length explicitly.
6497
64982002-11-19 Eric Botcazou <ebotcazou@libertysurf.fr>
35f1c975
EB
6499
6500 PR c/8588
6501 * optabs.c (expand_binop): Convert CONST_INTs in shift
6502 operations too.
6503
a500466b
RS
65042002-11-19 Roger Sayle <roger@eyesopen.com>
6505
6506 * gcse.c (gcse_emit_move_after): Correct typo in REG_EQUAL note.
6507
3b161153
KH
65082002-11-19 Kazu Hirata <kazu@cs.umass.edu>
6509
6510 * config/h8300/h8300.md (an anonymous pattern): Relax the
6511 condition to accept the same operands and/or subregs.
6512
85af47b9
DJ
65132002-11-19 Daniel Jacobowitz <drow@mvista.com>
6514
6515 * config/sh/sh.c (gen_shl_and): Revert previous patch.
6516 * config/sh/sh.md (ashrdi3+1, ashrdi3+2): Predicate on
6517 reload_completed.
6518
9675a91e
KH
65192002-11-19 Kazu Hirata <kazu@cs.umass.edu>
6520
6521 * config/h8300/h8300.c (print_operand): Update the use of
6522 EIGHTBIT_CONSTANT_ADDRESS_P.
6523 (h8300_adjust_insn_length): Likewise.
6524 (h8300_eightbit_constant_address_p): Check if the given rtx is
6525 a variable with __attribute__((eightbit_data)).
6526 * config/h8300/h8300.h (OK_FOR_U): Update the use of
6527 EIGHTBIT_CONSTANT_ADDRESS_P.
6528
7b61fa4d
GP
65292002-11-19 Gerald Pfeifer <pfeifer@dbai.tuwien.ac.at>
6530
6531 * doc/contrib.texi (Contributors): Add self as second contact in
6532 addition to Jeff Law.
6533
50aadcbc
AJ
65342002-11-19 Andreas Jaeger <aj@suse.de>
6535
6536 * tree-inline.c: Move prototpyes of find_alloca_call_1 and
6537 find_alloca_call to right place.
6538
dc65cd60
KH
65392002-11-19 Kazu Hirata <kazu@cs.umass.edu>
6540
6541 * cppfiles.c: Fix formatting.
6542
f3226a90
JT
65432002-11-19 Jason Thorpe <thorpej@wasabisystems.com>
6544
6545 * gcc.c (The Specs Language): Document spec functions.
6546 (static_spec_functions, lookup_spec_function)
6547 (eval_spec_function, handle_spec_function)
6548 (if_exists_spec_function, alloc_args): New.
6549 (execute): Abort if processing_spec_function is true.
6550 (do_spec_1): Hand off spec to handle_spec_function if %:
6551 is encountered. If processing_spec_function is true,
6552 end any pending argument when the end of the string is reached.
6553 (main): Use alloc_args to allocate the initial argument vector.
6554 * gcc.h (struct spec_function): New.
6555 (lang_specific_spec_functions): New extern.
6556
6557 * config/netbsd-elf.h (STARTFILE_SPEC): Add if-exists(crti%O%s).
6558 (ENDFILE_SPEC): Add if-exists(crtn%O%s).
6559 * config/alpha/netbsd.h (ENDFILE_SPEC): Likewise.
3bdcef4d 6560
f3226a90
JT
6561 * doc/invoke.texi: Document spec functions.
6562
6563 * cppspec.c (lang_specific_spec_functions): New.
6564 * gccspec.c: Likewise.
6565
08c42743
SE
65662002-11-18 Steve Ellcey <sje@cup.hp.com>
6567
6568 * config/ia64/hpux_longdouble.h (FIXUNS_TRUNCTFSI2_LIBCALL): New.
6569 (FIXUNS_TRUNCTFDI2_LIBCALL): New.
6570 (fixunstfsi_libfunc): Change.
6571 (fixunstfdi_libfunc): Change.
6572 (sdiv_optab): Don't zero out SImode handler.
6573 (udiv_optab): Don't zero out SImode handler.
6574 (smod_optab): Don't zero out SImode handler.
6575 (umod_optab): Don't zero out SImode handler.
6576
8128cccf
NB
65772002-11-18 Neil Booth <neil@daikokuya.co.uk>
6578
6579 PR preprocessor/8524
6580 * cpplib.c (run_directive): Remove previous kludge to _Pragma.
6581 Add a new one in its place, which hopefully works.
6582 (skip_rest_of_line): Change test for bottom-of-context-stack.
6583
95199202
JH
6584Mon Nov 18 21:29:03 CET 2002 Jan Hubicka <jh@suse.cz>
6585
6586 * i386.md (addqi_1_slp): Fix output template.
6587 (subqi_1_slp): Fix type.
6588
c986baf6
JH
6589Sun Nov 17 00:01:28 CET 2002 Jan Hubicka <jh@suse.cz>
6590
6591 * calls.c (alloca_call_p): New global function.
6592 * tree.h (alloca_call_p): New.
6593 * tree-inline.c (inlinable_function_p): Do not inline when
6594 function calls alloca.
6595 (find_alloca_call, find_alloca_call_1): New functions.
6596
ac655495
KH
65972002-11-18 Kazu Hirata <kazu@cs.umass.edu>
6598
6599 * config/h8300/h8300.md (*andorqi3): Use bor between bld and
6600 bst. Update the insn length.
6601 (*andorhi3): Likewise.
6602 (*andorsi3): Likewise.
6603
ea4210ef
RS
66042002-11-18 Richard Sandiford <rsandifo@redhat.com>
6605
6606 * config/sh/sh-protos.h (sh_mark_label): Declare.
6607 * config/sh/sh.c (sh_mark_label): New function, taken from
6608 movdi_const, but fixing the case when the address has an addend.
6609 * config/sh/sh.md (movdi_const, movdi_const_32bit): Use it.
6610
3503150c
RS
66112002-11-18 Richard Sandiford <rsandifo@redhat.com>
6612
6613 * config/sh/sh.c (pool_node): New field: part_of_sequence_p.
6614 (add_constant): Set it.
6615 (dump_table): Don't reorder a constant if part_of_sequence_p.
6616 (machine_dependent_reorg): Assume that float constants will
6617 stay in their original order if used as a sequence.
6618
180bde4f
RS
66192002-11-18 Richard Sandiford <rsandifo@redhat.com>
6620
6621 * config/sh/sh.c (calc_live_regs): Update check for PIC liveness
6622 in compact code.
6623
e300c78c
RS
66242002-11-18 Richard Sandiford <rsandifo@redhat.com>
6625
6626 * config/sh/sh.md (initialize_trampoline): Do not force the
6627 trampoline address into R0_REGS here.
6628
4977bab6
ZW
6629Sun Nov 17 14:01:09 CET 2002 Jan Hubicka <jh@suse.cz>
6630
6631 * i386.md (negsf2_ifs, negdf2_ifs, negdf2_ifs_rex64, abssf2_ifs,
6632 absdf2_ifs, absdf2_ifs_rex64): Fix constraints.
6633 (neg?f2_ifs, abs?f2_ifs splitters): Refuse memory operand; do not
6634 generate unnecesary subregs.
6635
ec748ec8
KH
66362002-11-17 Kazu Hirata <kazu@cs.umass.edu>
6637
6638 * df.c: Fix formatting.
6639
cf0cec73
KH
66402002-11-17 Kazu Hirata <kazu@cs.umass.edu>
6641
6642 * config/h8300/h8300.md (two anonymous patterns): Fix insn
6643 lengths.
6644
d2b2c7cd
DJ
66452002-11-17 Daniel Jacobowitz <drow@mvista.com>
6646
6647 * sh.c (gen_shl_and): Don't create a zero_extend if the operand
6648 is not an arith_reg_operand.
6649
6ddb1bc1
GS
66502002-11-17 Graham Stott <graham.stott@btinternet.com>
6651
6652 * real.c (real_to_decimal): Fix buffer overrun when buffer size
6653 is smaller than representation.
6654
5ab2f7b7
KH
66552002-11-17 Kazu Hirata <kazu@cs.umass.edu>
6656
6657 * builtins.c: Fix formatting.
6658
4977bab6
ZW
6659Sat Nov 16 16:49:58 CET 2002 Jan Hubicka <jh@suse.cz>
6660
6661 * i386.md (truncdfsf2_1_sse, truncdfsf2_1_sse_nooverlap, truncdfsf2_2,
6662 floats?dff2_i387):
6663 Work around regclass stupidity.
6664 (truncdfsf_2_1_sse splitter): Accept !TARGET_PARTIAL_SSE_REGS
6665
6666Sat Nov 16 02:17:48 CET 2002 Jan Hubicka <jh@suse.cz>
6667
6668 * i386.md (fop_df_6): New pattern.
6669 (fop_xf_4, fop_xf_5): Handle both SF and DFmode extensions.
6670 (fop_xf_6): Rewrite
6671 (fop_xf_7): Delete.
6672 (fop_tf_4, fop_tf_5): Handle both SF and DFmode extensions.
6673 (fop_tf_6): Rewrite
6674 (fop_tf_7): Delete.
6675
0d964e40
KH
66762002-11-16 Kazu Hirata <kazu@cs.umass.edu>
6677
6678 * config/h8300/h8300.md (two anonymous patterns): Fix typos.
6679
6d55e887
KH
66802002-11-16 Kazu Hirata <kazu@cs.umass.edu>
6681
6682 * config/h8300/h8300.md: Fix formatting.
6683
4d5ad877
KH
66842002-11-16 Kazu Hirata <kazu@cs.umass.edu>
6685
6686 * config/h8300/h8300.md: Replace spaces with tabs.
6687 * config/h8300/t-h8300: Remove a trailing empty line.
6688
17fa74a2
KH
66892002-11-16 Kazu Hirata <kazu@cs.umass.edu>
6690
6691 * tlink.c: Fix formatting.
6692
9caa3eb2
DE
66932002-11-16 David Edelsohn <edelsohn@gnu.org>
6694
68a7da97 6695 PR 8362
9caa3eb2
DE
6696 * config/rs6000/rs6000.c (rs6000_outout_load_multiple): New function.
6697 * config/rs6000/rs6000.md (movti_string): Remove output modifier
6698 when scratch register never needed.
6699 (ldmsi[3-8]): New patterns.
6700
476c5eb6
KH
67012002-11-16 Kazu Hirata <kazu@cs.umass.edu>
6702
6703 * hard-reg-set.h: Follow spelling conventions.
6704 * real.c: Likewise.
6705 * target.h: Likewise.
6706
5dab517f
JJ
67072002-11-16 Jakub Jelinek <jakub@redhat.com>
6708
6709 * config/i386/x86-64.h (MCOUNT_NAME): Change into string literal.
6710
7e1a450d
KH
67112002-11-16 Kazu Hirata <kazu@cs.umass.edu>
6712
6713 * optabs.c: Fix formatting.
6714
1b245ade
JH
6715Sat Nov 16 02:06:02 CET 2002 Jan Hubicka <jh@suse.cz>
6716
6717 * athlon.md, k6.md, pentium.md, ppro.md: Handle shift1, rotate1
6718 * i386.md (attribute type): Add type shift1 and rotate1.
6719 (*_slp): Rewrite to have just two operands to avoid reload problems.
6720
6368a493
KH
67212002-11-15 Kazu Hirata <kazu@cs.umass.edu>
6722
6723 * config/h8300/h8300.md (4 anonymous patterns): New.
6724
737c38d1
GK
67252002-11-15 Geoffrey Keating <geoffk@apple.com>
6726
6727 * params.def (GGC_MIN_HEAPSIZE): Fix GGC_ALWAYS_COLLECT problem.
6728 * doc/invoke.texi: Correct description of what needs to be done to
6729 force collection at every ggc_collect call.
6730
2120e3cd
UW
67312002-11-15 Ulrich Weigand <uweigand@de.ibm.com>
6732
3bdcef4d 6733 * config/s390/s390.c (optimization_options): Set
2120e3cd
UW
6734 flag_asynchronous_unwind_tables to 1 by default.
6735
18789f4e
UW
67362002-11-15 Ulrich Weigand <uweigand@de.ibm.com>
6737
6738 * config/s390/s390.h (ASM_PREFERRED_EH_DATA_FORMAT): Define.
6739
a5fa1ecd
JH
6740Fri Nov 15 14:54:19 CET 2002 Jan Hubicka <jh@suse.cz>
6741
6742 * i386-protos.h (x86_function_profiler): New function
6743 * i386.h (MCOUNT_NAME): New.
6744 (PROFILE_COUNT_REGISTER): New.
a36fc5f8 6745 (FUNCTION_PROFILER): Move offline to ...
a5fa1ecd
JH
6746 * i386.c (x86_function_profiler) ... here; fix 64bit support
6747 * beos-elf.h (FUNCTION_PROFILER): Kill.
6748 (MCOUNT_NAME): New.
6749 * freebsd-aout.h (FUNCTION_PROFILER): Kill.
6750 (MCOUNT_NAME): New.
6751 (PROFILE_COUNT_REGISTER): New.
6752 * linux.h (FUNCTION_PROFILER): Kill.
6753 (MCOUNT_NAME): New.
6754 * x86-64.h (FUNCTION_PROFILER): Kill.
6755 (MCOUNT_NAME): New.
6756 * freebsd.h (FUNCTION_PROFILER): Kill.
6757 (MCOUNT_NAME): New.
6758
1741620c
JD
67592002-11-14 Jeroen Dobbelaere <jeroen.dobbelaere@acunia.com>
6760
6761 * config/arm/arm.h (EXPAND_BUILTIN_VA_ARG,
6762 FUNCTION_ARG_PASS_BY_REFERENCE): Define.
6763 * config/arm/arm.c (arm_va_arg,
6764 arm_function_arg_pass_by_reference): New.
6765 * config/arm/arm-protos.h: Add prototypes.
6766
24985beb
KH
67672002-11-14 Kazu Hirata <kazu@cs.umass.edu>
6768
6769 * gthr-single.h: Fix formatting.
6770
fa7b533b
ZW
67712002-11-14 Zack Weinberg <zack@codesourcery.com>
6772
6773 * tree.c (tree_vec_elt_check_failed): New function.
6774 * tree.h (TREE_VEC_ELT_CHECK): New checking macro.
6775 (TREE_VEC_ELT): Use it.
6776
6777 * tree-inline.c (optimize_inline_calls): Don't copy a
6778 zero-length vector.
6779
9fc910d1
GDR
67802002-11-14 Gabriel Dos Reis <gdr@integrable-solutions.net>
6781
6782 * diagnostic.c (sorry): Don't repeat "sorry, unimplemented" text.
6783
7eca317a
JJ
67842002-11-14 Jakub Jelinek <jakub@redhat.com>
6785
6786 * varasm.c (output_addressed_constants) [MINUS_EXPR]: Clear reloc if
6787 both operands contain local relocations.
6788 (categorize_decl_for_section): Don't use mergeable sections if
6789 initializer has any relocations.
6790
57751dd6
KH
67912002-11-14 Kazu Hirata <kazu@cs.umass.edu>
6792
6793 * gthr-vxworks.h: Fix formatting.
6794
f702e700
JJ
67952002-11-13 Janis Johnson <janis187@us.ibm.com>
6796
6797 * doc/install.texi (Testing): Document extra Java testing.
6798 * doc/sourcebuild.texi (Test Suites): Document libgcj testing.
6799
08ec53e7
JDA
68002002-11-13 John David Anglin <dave@hiauly1.hia.nrc.ca>
6801
6802 * pa64-hpux.h (LINK_SPEC): Move "+Accept TypeMismatch" switch to the
6803 beginning of the spec.
6804 (LDD_SUFFIX, PARSE_LDD_OUTPUT): Delete.
6805 (LD_INIT_SWITCH, LD_FINI_SWITCH): Define but don't enable. Add comment
6806 regarding problems with global constructors when using GNU ld.
6807
e6179f45
KH
68082002-11-13 Kazu Hirata <kazu@cs.umass.edu>
6809
6810 * gthr-solaris.h: Fix formatting.
6811
fe83a9ce
KH
68122002-11-13 Kazu Hirata <kazu@cs.umass.edu>
6813
6814 * gthr-posix.h: Fix formatting.
6815
4977bab6 68162002-11-12 Devang Patel <dpatel@apple.com>
4977bab6
ZW
6817 * gcc.c (display_help): Two new options -Xpreprocessor and -Xassembler.
6818 (process_command): Same.
6819 * doc/invoke.texi: Info about these two new options.
6820
eed13f9b
KH
68212002-11-12 Kazu Hirata <kazu@cs.umass.edu>
6822
6823 * config/h8300/h8300.md (*andorsi3): New.
6824
e8a7b0c2
FS
68252002-11-12 Franz Sirl <Franz.Sirl-kernel@lauterbach.com>
6826
6827 * doc/install.texi (powerpc-*-linux-gnu*): Update binutils requirement.
6828
94aec8dd
KH
68292002-11-12 Kazu Hirata <kazu@cs.umass.edu>
6830
6831 * config/h8300/h8300.c (tiny_constant_address_p): Parenthesize
6832 expressions appropriately.
6833
fc98f5cb
KH
68342002-11-12 Kazu Hirata <kazu@cs.umass.edu>
6835
6836 * gthr-win32.h: Fix formatting.
6837
e27051f7
KH
68382002-11-12 Kazu Hirata <kazu@cs.umass.edu>
6839
6840 * config/h8300/h8300.c (single_one_operand): Correctly compute
6841 mask when mode is SImode.
6842 (single_zero_operand): Likewise.
6843 * config/h8300/h8300.md (two new anonymous insns): New.
6844
10bb8214
GP
68452002-11-12 Gerald Pfeifer <pfeifer@dbai.tuwien.ac.at>
6846
6847 * doc/contrib.texi (Contributors): Use GCJ instead of gcj to refer
6848 to that entire project.
6849
ffe11c6b
RO
68502002-11-12 Rainer Orth <ro@TechFak.Uni-Bielefeld.DE>
6851
6852 * config/mips/t-iris6 (MULTILIB_OSDIRNAMES): Restore old
6853 directories.
6854
3788cc17
ZW
68552002-11-11 Zack Weinberg <zack@codesourcery.com>
6856
6857 * params.def (ggc-min-expand, ggc-min-heapsize): New parameters.
6858 * doc/invoke.texi: Document them.
6859
6860 * ggc-page.c: Include params.h. Remove definitions of
6861 GGC_MIN_EXPAND_FOR_GC, GGC_MIN_LAST_ALLOCATED. Replace
6862 GGC_POISON with ENABLE_GC_CHECKING in ifdefs, delete #define.
6863 (init_gcc): Don't set G.allocated_last_gc here.
6864 (ggc_collect): Use PARAM_VALUE (GGC_MIN_HEAPSIZE) and
6865 PARAM_VALUE (GGC_MIN_EXPAND) to decide whether or not to
6866 perform collection.
6867 * ggc-simple.c: Similarly.
6868 * Makefile.in (ggc-common.o, ggc-simple.o): Add $(PARAMS_H) to
6869 dependencies.
6870
dd697f8c
KH
68712002-11-11 Kazu Hirata <kazu@cs.umass.edu>
6872
6873 * gthr-dce.h: Fix formatting.
6874
303b90b0
FS
68752002-11-11 Franz Sirl <Franz.Sirl-kernel@lauterbach.com>
6876
6877 PR c/8467
6878 * stmt.c (tail_recursion_args): Handle DECL_MODE differing from the
6879 mode of DECL_RTL case.
6880
e8437165
JJ
68812002-11-11 Janis Johnson <janis187@us.ibm.com>
6882
6883 * doc/contrib.texi: Merge in the list from the libstdc++ web pages.
6884
12f5c45e
JH
6885Mon Nov 11 12:06:08 CET 2002 Jan Hubicka <jh@suse.cz>
6886
6887 * i386.c (construct_container): Fix handling of SSE_CLASS.
6888
f981a754
JS
68892002-11-10 Joel Sherrill <joel@gcc.gnu.org>
6890
6891 * config/m68k/t-crtstuff (crti.o): Use this...
6892 ($(T)crti.o): ... instead.
6893 (crtn.o): Use this...
6894 ($(T)crtn.o): ... instead.
6895
a9b6f1e7 68962002-11-10 Eric Botcazou <ebotcazou@libertysurf.fr>
45ed7228
EB
6897
6898 PR c/8439
6899 * recog.c (validate_replace_rtx_1) [PLUS]: Simplify only
6900 if there is something new to be simplified.
6901
2da4124d
L
69022002-11-10 H.J. Lu <hjl@gnu.org>
6903
6904 * calls.c (PUSH_ARGS_REVERSED): Define only if not defined.
6905 * expr.c (PUSH_ARGS_REVERSED): Likewise.
6906
6907 * config/i386/i386.h (PUSH_ARGS_REVERSED): Set to 1.
6908
7bb9f927
ZW
69092002-11-10 Zack Weinberg <zack@codesourcery.com>
6910
6911 * config/rs6000/sysv4.h: Define NO_IMPLICIT_EXTERN_C here...
6912 * config/rs6000/linux.h, config/rs6000/linux64.h,
6913 config/rs6000/windiss.h: ... not here.
6914
d8986082
JT
69152002-11-10 Jason Thorpe <thorpej@wasabisystems.com>
6916
6917 * config/mips/netbsd.h (TARGET_OS_CPP_BUILTINS): Define
6918 __ABICALLS__ if TARGET_ABICALLS.
6919
2e64c636
JH
6920Sun Nov 10 18:49:21 CET 2002 Jan Hubicka <jh@suse.cz>
6921
6922 * i386.h (MIN_UNITS_PER_WORD): Define to 8 for x86-64 libgcc.
6923
04e6db94
JM
69242002-11-10 Joseph S. Myers <jsm@polyomino.org.uk>
6925
6926 * c-decl.c (grokdeclarator): Make error for duplicate type
6927 qualifiers into a pedwarn, disabled for C99.
6928
e9986d3a
HPN
69292002-11-10 Hans-Peter Nilsson <hp@bitrange.com>
6930
6931 * config/mmix/mmix.h (FUNCTION_ARG_CALLEE_COPIES): Define the same
6932 as FUNCTION_ARG_PASS_BY_REFERENCE.
6933
4977bab6
ZW
69342002-11-09 Zack Weinberg <zack@codesourcery.com>
6935
6936 * doc/install.texi: Add *-*-vxworks* specific installation
6937 instructions.
6938
6939 * config/vxlib.c: Rewrite using generation numbers to identify
6940 valid TSD keys.
6941
6942Sat Nov 9 00:10:54 CET 2002 Jan Hubicka <jh@suse.cz>
6943
6944 * i386.c (x86_machine_dependent_reorg): Fix even more side cases.
6945
581d9404
JDA
69462002-11-09 John David Anglin <dave@hiauly1.hia.nrc.ca>
6947
6948 * pa.h (STARTING_FRAME_OFFSET): Change offset for TARGET_64BIT to 16.
6949
6950 * config.gcc (hppa*64*-*-linux*): Shorten lines in tm_file define.
6951 (hppa*64*-*-hpux11*): Likewise. Use elfos.h with gas.
6952 * pa.c (output_millicode_call): Use symbol difference rather than
6953 $PIC_pcrel$0 when using HP assembler.
6954 * pa64-hpux.h (TARGET_GAS): Define to 1 or 0 depending on whether or
6955 not elfos.h (i.e., gas) is being used.
6956 (ASM_FILE_START, STRING_ASM_OP, TEXT_SECTION_ASM_OP,
6957 DATA_SECTION_ASM_OP, BSS_SECTION_ASM_OP, ASM_OUTPUT_ALIGNED_COMMON,
6958 ASM_OUTPUT_ALIGNED_LOCAL, GLOBAL_ASM_OP, ASM_DECLARE_FUNCTION_NAME,
6959 ASM_OUTPUT_EXTERNAL, ASM_OUTPUT_EXTERNAL_LIBCALL,
6960 ASM_OUTPUT_INTERNAL_LABEL, ASM_GENERATE_INTERNAL_LABEL): Define when
6961 using elfos.h.
6962 (TARGET_ASM_GLOBALIZE_LABEL): Undefine when using elfos.h.
6963 (DWARF2_ASM_LINE_DEBUG_INFO): Delete.
6964 (ASM_FILE_START): Add standard .SPACE and .SUBSPA defines when not
6965 using elfos.h.
6966 (TEXT_SECTION_ASM_OP, READONLY_DATA_SECTION_ASM_OP, DATA_SECTION_ASM_OP,
6967 BSS_SECTION_ASM_OP): New HP style defines when not using elfos.h.
6968 (TARGET_ASM_NAMED_SECTION, MAKE_DECL_ONE_ONLY, ASM_WEAKEN_LABEL):
6969 Don't define when not using elfos.h.
6970 (ASM_DECLARE_RESULT): Don't define.
6971 * doc/install.texi (hppa*-hp-hpux*): Remove statement that HP assembler
6972 doesn't work on hppa64-hp-hpux11.
6973 (hppa*-hp-hpux11): Update.
6974
9f689d92
JT
69752002-11-09 Jason Thorpe <thorpej@wasabisystems.com>
6976
6977 * config/mips/netbsd.h (SUBTARGET_ASM_SPEC): Don't pass -KPIC
6978 to the assembler if -mno-abicalls was specified.
6979
1c03af86
JDA
69802002-11-09 John David Anglin <dave@hiauly1.hia.nrc.ca>
6981
6982 * pa-linux.h (PREFERRED_DEBUGGING_TYPE, DWARF2_ASM_LINE_DEBUG_INFO,
6983 ASM_OUTPUT_DEF): Delete.
6984
57800e9e
NB
69852002-11-09 Neil Booth <neil@daikokuya.co.uk>
6986
6987 * c-opts.c (COMMAND_LINE_OPTIONS): Fix -Wimplicit.
6988
4977bab6
ZW
69892002-11-08 Roger Sayle <roger@eyesopen.com>
6990
6991 * real.c (real_sqrt): Update comment with bibliographic reference.
6992
6993Fri Nov 8 13:33:58 CET 2002 Jan Hubicka <jh@suse.cz>
6994
6995 * i386.md (sse_loadss, sse2_loadsd): Fix expander.
6996
6997Fri Nov 8 13:25:41 CET 2002 Jan Hubicka <jh@suse.cz>
6998
6999 * i386.c (x86_machine_dependent_reorg): Fix handling of empty functions.
7000
7001Fri Nov 8 13:01:42 CET 2002 Jan Hubicka <jh@suse.cz>
7002
7003 * builtins.c (expand_builtin_mathfn): Handle floor/ceil/trunc/round/nearbyint
7004 (expand_builtin): Likewise.
7005 * builtins.def: Add
7006 __builtin_floor, __builtin_floorf, __builtin_floorl
7007 __builtin_ceil, __builtin_ceilf, __builtin_ceill
7008 __builtin_round, __builtin_roundf, __builtin_roundl
7009 __builtin_trunc, __builtin_truncf, __builtin_truncl
7010 __builtin_nearbyint, __builtin_nearbyintf, __builtin_nearbyintl.
7011 * genopinit.c (optabs): Initialize the new optabs.
7012 * optab.c (init_optabs): Likewise.
7013 * optabs.h (optab_index): Add OTI_floor, OTI_ceil, OTI_trunc,
7014 OTI_round, OTI_nearbyint.
7015 (floor_optab, ceil_optab, trunc_optab, round_optab, nearbyint_optab): New.
7016 * doc/md.texi: Document new named patterns.
7017 * doc/extend.texi (builtin functions) Document
7018 floor, floorf, floorl, ceil, ceilf,
7019 ceill, round, roundf, roundl, trunc,
7020 truncf, truncl, nearbyint, nearbyintf, nearbyintl.
7021
7022Fri Nov 8 11:36:11 CET 2002 Jan Hubicka <jh@suse.cz>
7023
7024 * i386.md (sse_movdfcc, sse_movsfcc): Fix typo in previous patch.
7025
489d6e8e
DJ
70262002-11-08 Dale Johannesen <dalej@apple.com>
7027
7bb9f927 7028 * dbxout.c (dbxout_type): Fix stabs info for vector types.
489d6e8e 7029
a4b1e653
NB
70302002-11-08 Neil Booth <neil@daikokuya.co.uk>
7031
7032 PR preprocessor/8497
7033 PR preprocessor/8501
7034 * cpptrad.c (scan_out_logical_line): A '#' from a macro doesn't
7035 start a directive. In assembler, #NUM is not a line directive.
7036
e6e8c772
NB
70372002-11-08 Neil Booth <neil@daikokuya.co.uk>
7038
7039 * cppmain.c (cpp_preprocess_file): Loop to pop any -included
7040 buffers.
7041
ffdf5eae
KH
70422002-11-08 Kazu Hirata <kazu@cs.umass.edu>
7043
7044 * config/h8300/h8300.md (two anonymous test insns): New.
7045
8dd3ca88
JH
7046Fri Nov 8 11:20:19 CET 2002 Jan Hubicka <jh@suse.cz>
7047
7048 * jump.c (mark_jump_label): Handle subregs of label_refs.
7049
4977bab6
ZW
7050Thu Nov 7 21:54:22 CET 2002 Jan Hubicka <jh@suse.cz>
7051
7052 * i386.md (sse_movdfcc, sse_movsfcc): Avoid overactive matching.
7053 * i386.c (ix86_expand_fp_movcc): Match the reversed cases.
7054
07cf4226
DM
70552002-11-07 David Mosberger <davidm@hpl.hp.com>
7056
7bb9f927
ZW
7057 * config/ia64/crtend.asm: Include "auto-host.h".
7058 [HAVE_INITFINI_ARRAY]: Invoke __do_global_ctors_aux via .init_array.
7059 * config/ia64/crtbegin.asm: Similarly.
7060 * config/ia64/t-ia64 (crtbegin.o): Include from current directory.
7061 (crtend.o, crtbeginS.o, crtendS.o): Likewise.
07cf4226 7062
7bb9f927
ZW
7063 * aclocal.m4 (gcc_AC_INITFINI_ARRAY): New.
7064 * configure.in: Use it if --enable-initfini-array not specified.
7065 * doc/install.texi (Configuration): Document --enable-initfini-array.
07cf4226
DM
7066 * configure, config.in: Rebuild.
7067
0977774b 70682002-11-07 Jason Thorpe <thorpej@wasabisystems.com>
7bb9f927 7069
0977774b 7070 * config/arm/arm-protos.h (arm_get_frame_size)
7bb9f927 7071 (thumb_get_frame_size): New prototypes.
0977774b 7072 * config/arm/arm.c (arm_get_frame_size)
7bb9f927
ZW
7073 (thumb_get_frame_size): New functions.
7074 (use_return_insn, arm_output_epilogue, arm_output_function_epilogue)
7075 (arm_compute_initial_elimination_offset, arm_expand_prologue): Use
0977774b
JT
7076 arm_get_frame_size.
7077 (thumb_expand_prologue, thumb_expand_epilogue): Use
7078 thumb_get_frame_size.
7079 * config/arm/arm.h (PREFERRED_STACK_BOUNDARY): Define.
7080 (machine_function): Add frame_size member.
7081 (THUMB_INITIAL_ELIMINATION_OFFSET): Use thumb_get_frame_size.
7082
70832002-11-07 Richard Earnshaw <rearnsha@arm.com>
7084
7085 * arm.c (bit_count): Make argument unsigned long. Return unsigned.
7086 Adjust code to use portable unsigned bit manipulation.
7087 (insn_flags, tune_flags): Change type to unsigned.
7088 (struct processors): Make flags unsigned long.
7089 (arm_override_options): Change type of count and current_bit_count
7090 to unsigned.
7091
74c13308
RE
70922002-11-07 Richard Earnshaw <rearnsha@arm.com>
7093
7094 * arm/elf.h (TYPE_OPERAND_FMT): Prefix type with %.
7095
e284643a
R
7096Thu Nov 7 15:50:18 2002 J"orn Rennecke <joern.rennecke@superh.com>
7097
7098 * sh.h (DWARF_FRAME_RETURN_COLUMN): Use DWARF_FRAME_REGNUM.
7099
c2905f7b
JH
7100Thu Nov 7 11:18:01 CET 2002 Jan Hubicka <jh@suse.cz>
7101
7102 * reg-stack.c (compensate_edge): Fix sanity check.
7103
3cfe49da
GK
71042002-11-05 Geoffrey Keating <geoffk@apple.com>
7105
7106 * config.gcc: Don't create crtbegin, crtend on Darwin; do create
7107 crt2.o. Rearrange t-darwin makefiles.
7108 * crtstuff.c [OBJECT_FORMAT_MACHO]: Delete.
7109 * unwind-dw2-fde-darwin.c: New.
7110 * unwind-dw2-fde-glibc.c: Correct comment.
7111 * unwind-dw2-fde.c (__register_frame_info_bases)
7112 [DWARF2_OBJECT_END_PTR_EXTENSION]: Clear fde_end.
7113 (classify_object_over_fdes): Use last_fde.
7114 (add_fdes): Likewise.
7115 (linear_search_fdes): Likewise.
7116 * unwind-dw2-fde.h (struct object)
7117 [DWARF2_OBJECT_END_PTR_EXTENSION]: Add fde_end field.
7118 (last_fde): New.
7119 * config/darwin.h (STARTFILE_SPEC): Include crt2.o not crtbegin.o.
7120 (ENDFILE_SPEC): No crtend.o.
7121 * config/t-darwin: New.
7122 * config/i386/t-darwin: Delete.
7123 * config/darwin-crt2.c: New.
7124 * config/rs6000/t-darwin: Delete contents duplicated in t-rs6000
7125 or config/t-darwin.
7126
4977bab6
ZW
71272002-11-06 Douglas B Rupp <rupp@gnat.com>
7128
7129 * config/i386/i386-interix.h (TARGET_SUBTARGET_DEFAULT): Or
7130 MASK_MS_BITFIELD_LAYOUT
7131 (SUBTARGET_OVERRIDE_OPTIONS): Warn about and turn off
7132 MS bitfields for Objective-C.
7133 (PCC_BIT_FIELD_TYPE_TEST, GROUP_BITFIELDS_BY_ALIGN): Remove
7134 defines.
7135
7136 * config/i386/i386.c (ix86_ms_bitfield_layout): New function.
7137 (TARGET_MS_BITFIELD_LAYOUT_P): Define to above function.
7138 (TARGET_USE_MS_BITFIELD_LAYOUT): Define.
7139
7140 * config/i386/i386.h (MASK_MS_BITFIELD_LAYOUT: New mask.
7141 TARGET_USE_MS_BITFIELD_LAYOUT): New macro.
7142 (TARGET_SWITCHES): Add above mask.
7143
7144 * testsuite/gcc.dg/bf-ms-layout.c: New test case.
7145 * testsuite/gcc.dg/bf-no-ms-layout.c: New test case.
7146 * testsuite/gcc.dg/i386-bitfield1.c (dg-options): Add appropriate
7147 flags for interix.
7148
7149Wed Nov 6 18:54:47 2002 Alexandre Oliva <aoliva@redhat.com>
7150
7151 * config/mips/mips.h (ASM_OUTPUT_ADDR_DIFF_ELT): Output
7152 .gpword/.gpdword for ABI_N32 and ABI_64 too, if using the GNU
7153 assembler.
7154 * config/mips/mips.md (tablejump_internal3): Output .cpadd
7155 before jump on ABI_N32 too.
7156 (tablejump_internal4): Ditto on ABI_64. Increase maximum
7157 length to match.
7158
7159Wed Nov 6 17:16:48 CET 2002 Jan Hubicka <jh@.suse.cz>
7160
7161 * i386.md (negsf splitter): Accept memory operand in second register.
7162 (abssf/absdf splitters): Simplify
7163 (sse_loadss, sse_loadsd): Turn into expander.
7164
5d7e6254
DE
71652002-11-06 David Edelsohn <edelsohn@gnu.org>
7166
7167 PR target/8480
7168 * config/rs6000/rs6000.md (movdi_internal64): Discourage
7169 FPR to FPR moves.
7170
4fc6ad08
JJ
71712002-11-06 Janis Johnson <janis187@us.ibm.com>
7172
7173 * doc/contrib.texi: Merge in the list from the Java web pages.
7174
fa123c53
DB
71752002-11-06 David O'Brien <obrien@FreeBSD.org>
7176
7177 * config/sparc/freebsd: Fix typo.
7178
81e5bc3d
JDA
71792002-11-06 John David Anglin <dave@hiauly1.hia.nrc.ca>
7180
7181 * pa64-hpux.h (LDD_SUFFIX, PARSE_LDD_OUTPUT): Define.
7182
021fa809
AO
71832002-11-06 Alexandre Oliva <aoliva@redhat.com>
7184
7185 * config/mips/mips.md (call_value_multiple_internal2): Use dla for
7186 non-SImode addresses.
7187
4977bab6
ZW
7188Tue Nov 5 14:34:36 CET 2002 Jan Hubicka <jh@suse.cz>
7189
7190 * i386.md (float_truncate SSE splitter): Ensure that operand is not
7191 stack register.
7192 (float SSE splitters): Reorder conditional.
7193
e9577224
BW
71942002-11-05 Bob Wilson <bob.wilson@acm.org>
7195
7196 * config/xtensa/elf.h (LIB_SPEC): Add "-lhal".
7197
a9b11d44
JDA
71982002-11-05 John David Anglin <dave2hiauly1.hia.nrc.ca>
7199
7200 * pa64-hpux.h (LIB_SPEC): Fix p and pg options.
7201 (STARTFILE_SPEC): Remove p and pg options.
7202
5c7cd663
AH
72032002-11-05 Andrew Haley <aph@redhat.com>
7204
7205 * fold-const.c (fold): Don't transform (a0 op compound(a1,a2))
7206 to (compound(a1,a0 op a2)) if a0 or a1 have side effects.
7207
97ab1175
RS
72082002-11-05 Richard Sandiford <rsandifo@redhat.com>
7209
7210 * config/mips/mips.h (CANNOT_CHANGE_MODE_CLASS): Move comment to...
7211 * config/mips/mips.c (mips_cannot_change_mode_class): ...here.
7212
4977bab6
ZW
72132002-11-04 Zack Weinberg <zack@codesourcery.com>
7214
7215 * gthr-vxworks.h: Rewritten from scratch.
7216 * config/vxlib.c: New file.
7217 * config/t-vxworks: Add config/vxlib.c to LIB2FUNCS_EXTRA.
7218 * config/rs6000/t-vxworks: Add config/vxlib.c to
7219 LIB2FUNCS_EXTRA here too, because of clash with
7220 config/rs6000/t-ppccomm.
7221
2aff9508
DJ
72222002-11-04 Dale Johannesen <dalej@apple.com>
7223
7bb9f927
ZW
7224 * doloop.c (doloop_modify_runtime): Fix loop count computation
7225 for unrolled loops.
2aff9508
DJ
7226 * loop.c (loop_invariant_p): Support calling from unroller.
7227
e86e721f
UW
72282002-11-04 Ulrich Weigand <uweigand@de.ibm.com>
7229
7230 * config/s390/s390.c (s390_decompose_address): Use arg_pointer_rtx
7231 for comparison.
7232
cff9f8d5
AH
72332002-11-04 Aldy Hernandez <aldyh@redhat.com>
7234
7235 * hard-reg-set.h (REG_CANNOT_CHANGE_MODE_P): New.
7236
7237 * config/rs6000/rs6000.h (CLASS_CANNOT_CHANGE_MODE_P): Remove.
7238 (CLASS_CANNOT_CHANGE_MODE): Remove.
7239 (CANNOT_CHANGE_MODE_CLASS): New.
7240
7241 * config/alpha/alpha.h: Same.
7242
7243 * config/ia64/ia64.h: Same.
7244
7245 * config/mips/mips.h: Same.
7246
7247 * config/s390/s390.h: Same.
7248
7249 * config/sh/sh.h: Same.
7250
7251 * config/pa/pa64-regs.h: Same.
7252
7253 * config/sh/sh-protos.h (sh_cannot_change_mode_class): Add prototype.
7bb9f927 7254
cff9f8d5
AH
7255 * config/sh/sh.c (sh_cannot_change_mode_class): New.
7256
7257 * config/mips/mips-protos.h (mips_cannot_change_mode_class): Add
7258 prototype.
7259
7260 * config/mips/mips.c (mips_cannot_change_mode_class): New.
7261
7262 * doc/tm.texi (Register Classes): Remove
7263 CLASS_CANNOT_CHANGE_MODE and CLASS_CANNOT_CHANGE_MODE_P.
7264 Document CANNOT_CHANGE_MODE_CLASS.
7265
7266 * reload.c (push_reload): Use CANNOT_CHANGE_MODE_CLASS.
7267 (push_reload): Same.
7268
7269 * simplify-rtx.c (simplify_subreg): Same.
7270
7271 * reload1.c (choose_reload_regs): Same.
7272
7273 * recog.c (register_operand): Same.
7274
7275 * regrename.c (mode_change_ok): Change to use new
7276 CANNOT_CHANGE_MODE_CLASS infrastructure.
7277
7278 * regclass.c (cannot_change_mode_set_regs): New.
7279 Declare subregs_of_mode.
7280 (regclass): Use subregs_of_mode.
7281 Remove references to reg_changes_mode.
7282 (init_reg_sets_1): Remove class_can_change_mode and
7283 reg_changes_mode code.
7284 (invalid_mode_change_p): New.
7285 (dump_regclass): Use invalid_mode_change_p instead of
7286 class_can_change_mode.
7287 (regclass): Same.
7288 (record_operand_costs): Do not set reg_changes_mode.
7289
7290 * local-alloc.c (struct qty): Remove changes_mode field.
7291 (alloc_qty): Remove changes_mode initialization.
7292 (update_qty_class): Remove set of changes_mode.
7293 (find_free_reg): Use subregs_of_mode.
7294
7295 * global.c (find_reg): Use subregs_of_mode info.
7296
7297 * rtl.h (cannot_change_mode_set_regs): New prototype.
7298 (invalid_mode_change_p): Same.
7299 (REG_CANNOT_CHANGE_MODE_P): New macro.
7300
7301 * flow.c (mark_used_regs): Calculate subregs_of_mode. Remove
7302 REG_CHANGES_MODE.
7303 (life_analysis): Clear subregs_of_mode.
7304
7305 * combine.c (subst): Pass class to CLASS_CANNOT_CHANGE_MODE_P.
7306 Remove use of CLASS_CANNOT_CHANGE_MODE.
7307 (simplify_set): Same.
7308 (gen_lowpart_for_combine): Calculate subregs_of_mode. Remove
7309 REG_CHANGES_MODE.
7bb9f927 7310
cff9f8d5
AH
7311 * regs.h: Add extern for subregs_of_mode;
7312 Include hard-reg-set and basic-block.
7313 (REG_CHANGES_MODE): Delete.
7314
4977bab6
ZW
73152002-11-03 Roger Sayle <roger@eyesopen.com>
7316
7317 * real.c (real_sqrt): New function to calculate square roots.
7318 * real.h (real_sqrt): Add function prototype.
7319 * builtins.c (fold_builtin): Fold sqrt of constant argument.
7320 * simplify-rtx.c (simplify_unary_operation): Simplify sqrt
7321 of constant argument.
7322
2ff363e0
JDA
73232002-11-03 John David Anglin <dave@hiauly1.hia.nrc.ca>
7324
7325 * jump.c (never_reached_warning): Don't set contains_insn until the
7326 first line note is seen.
7327
cd1d3445
DE
73282002-11-03 David Edelsohn <edelsohn@gnu.org>
7329
7330 * config/rs6000/rs6000.md (movti_string): Use string instructions.
7331
c9fe6f9f
RS
73322002-11-03 Roger Sayle <roger@eyesopen.com>
7333
7334 PR c/7128
7335 * c-typeck.c (c_expand_asm_operands): Defend against
7336 error_mark_nodes in the output argument to avoid ICE.
7337
0b40e88e
EB
73382002-11-03 Eric Botcazou <ebotcazou@libertysurf.fr>
7339
7340 PR middle-end/8408
7341 * genrecog.c (preds): Handle ADDRESSOF.
7342 (validate_pattern): Mark it as an lvalue.
7343
dff9f1b6
DE
73442002-11-02 David Edelsohn <edelsohn@gnu.org>
7345
7346 * config/rs6000/rs6000.c (rs6000_override_options): Use string
7347 instructions when optimizing for size.
7348
46eefac4
KH
73492002-11-02 Kazu Hirata <kazu@cs.umass.edu>
7350
7351 * config/h8300/h8300.h: Fix comment typos.
7352 * config/h8300/h8300.md: Likewise.
7353 * config/h8300/lib1funcs.asm: Likewise.
7354
102b60d1
GP
73552002-11-02 Gerald Pfeifer <pfeifer@dbai.tuwien.ac.at>
7356
7357 Revert this change:
7358
7359 *doc/install.texi (Installing GCC: Configuration): Clarify
7360 the only supported ways to configure gcc.
7361
46be79e7
KH
73622002-11-01 Kazu Hirata <kazu@cs.umass.edu>
7363
7364 * config/h8300/h8300.md (anonymous and:QI pattern): Use 'n'
7365 instead of 'O' for the constraint for the second operand.
7366
bec80a45
MM
73672002-11-01 Mark Mitchell <mark@codesourcery.com>
7368
7369 PR c++/8391
7370 * toplev.c (rest_of_compilation): Do not refuse to output code for
7371 an inline function in a local class.
7372
8df91177
DB
73732002-11-01 David O'Brien <obrien@FreeBSD.org>
7374
7375 * config/sparc/freebsd.h (CPP_CPU64_DEFAULT_SPEC): Define __arch64__.
7376 (TRANSFER_FROM_TRAMPOLINE): Reformat.
7377 Add comment.
7378
616dc555
KH
73792002-11-01 Kazu Hirata <kazu@cs.umass.edu>
7380
7381 * config/h8300/h8300.h (CAN_ELIMINATE): Simplify.
7382
25a533a0
TM
73832002-11-01 Toshiyasu Morita <toshiyasu.morita@hsa.hitachi.com>
7384
7385 * config/h8300/h8300.h (OPTIMIZATION_OPTIONS): New.
7386
dcffbade
SE
73872002-11-01 Steve Ellcey <sje@cup.hp.com>
7388
7389 * config/ia64/ia64.h (MASK_INLINE_DIV_LAT): Remove.
7390 (MASK_INLINE_DIV_THR): Remove.
7391 (TARGET_INLINE_DIV_LAT): Remove.
7392 (TARGET_INLINE_DIV_THR): Remove.
7393 (TARGET_INLINE_DIV): Remove.
7394 (MASK_INLINE_FLOAT_DIV_LAT): New macro.
7395 (MASK_INLINE_FLOAT_DIV_THR): New macro.
7396 (MASK_INLINE_INT_DIV_LAT): New macro.
7397 (MASK_INLINE_INT_DIV_THR): New macro.
7398 (TARGET_INLINE_FLOAT_DIV_LAT): New macro.
7399 (TARGET_INLINE_FLOAT_DIV_THR): New macro.
7400 (TARGET_INLINE_INT_DIV_LAT): New macro.
7401 (TARGET_INLINE_INT_DIV_THR): New macro.
7402 (TARGET_INLINE_FLOAT_DIV): New macro.
7403 (TARGET_INLINE_INT_DIV): New macro.
7404 * config/ia64/ia64.md (divsi3): Change to use new macros.
7405 (modsi3): Ditto.
7406 (udivsi3): Ditto.
7407 (umodsi3): Ditto.
7408 (divsi3_internal): Ditto.
7409 (divdi3): Ditto.
7410 (moddi3): Ditto.
7411 (udivdi3): Ditto.
7412 (umoddi3): Ditto.
7413 (divdi3_internal_lat): Ditto.
7414 (divdi3_internal_thr): Ditto.
7415 (divsf3): Ditto.
7416 (divsf3_internal_lat): Ditto.
7417 (divsf3_internal_thr): Ditto.
7418 (divdf3): Ditto.
7419 (divdf3_internal_lat): Ditto.
7420 (divdf3_internal_thr): Ditto.
7421 (divtf3): Ditto.
7422 (divtf3_internal_lat): Ditto.
7423 (divtf3_internal_thr): Ditto.
7424 * config/ia64/ia64.c (ia64_override_options): Change
7425 to check new macros for conflicts in settings.
7426 * doc/invoke.texi (-minline-divide-min-latency): Remove.
7427 (-minline-divide-max-throughput): Remove.
7428 (-minline-float-divide-min-latency): New.
7429 (-minline-float-divide-max-throughput): New.
7430 (-minline-int-divide-min-latency): New.
7431 (-minline-int-divide-max-throughput): New.
7bb9f927 7432
d5db54a1
RE
74332002-11-01 Richard Earnshaw (rearnsha@arm.com)
7434
7435 PR target/7856
7436 * arm.c (use_return_insn): Don't use a return insn if there are
7437 saved integer regs, but LR is not one of them.
7438
075fc17a
JH
7439Fri Nov 1 10:33:15 CET 2002 Jan Hubicka <jh@suse.cz>
7440
7441 * expr.c (emit_move_insn): Use SCALAR_FLOAT_MODE_P
7442 * machmode.h (SCALAR_FLOAT_MODE_P): New macro.
7443
4977bab6
ZW
7444Thu Oct 31 18:20:50 CET 2002 Jan Hubicka <jh@suse.cz>
7445
7446 * i386.md (sse_loadss, sse_loadsd): Canonicalize; add expander
7447 (movps, movpd splitters): Use canonical form.
7448 (movv2di): Fix merge problem.
7449
7450Thu Oct 31 16:22:31 CET 2002 Jan Hubicka <jh@suse.cz>
7451
7452 * i386.md (negdf2_ifs_rex64): Don't allow GPR operand.
7453
9efb4cb6
NN
74542002-10-31 Nathanael Nerode <neroden@gcc.gnu.org>
7455
7456 PR optimization/6162
7457 * doc/md.texi: Document restriction on commutative operand
7458 specification.
7459
ce02ba25
EC
74602002-10-31 Eric Christopher <echristo@redhat.com>
7461
7bb9f927 7462 * explow.c (convert_memory_address): Use shallow_copy_rtx.
ce02ba25 7463
8efb33ec
SE
74642002-10-31 Steve Ellcey <sje@cup.hp.com>
7465
7466 * expmed.c (store_bit_field): Check FUNCTION_ARG_REG_LITTLE_ENDIAN.
7467
a543c709
SE
74682002-10-31 Steve Ellcey <sje@cup.hp.com>
7469
7470 * config/ia64/hpux.h (MEMBER_TYPE_FORCES_BLK): Set for non-floats.
7471
cdc58a82
DJ
7472Thu Oct 31 Dale Johannesen <dalej@apple.com>
7473
7474 * config/rs6000/darwin.h: Correct formatting in previous.
7475
e381c27a
DJ
7476Thu Oct 31 Dale Johannesen <dalej@apple.com>
7477
7478 * config/rs6000/darwin.h: Enable -falign-xxx options.
7479
55ba61f3
JH
7480Thu Oct 31 18:08:00 CET 2002 Jan Hubicka <jh@suse.cz>
7481
7482 * i386.c (override_options): Set defaults for flag_omit_frame_pointer,
7483 flag_asynchronous_unwind_tables, flag_pcc_struct_return.
7484 * i386.c (optimization_options): Set flag_omit_frame_pointer,
7485 flag_asynchronous_unwind_tables, flag_pcc_struct_return to 2.
7486 Do not clear -momit-leaf-frame-pointer when profiling.
8e746279 7487 (ix86_frame_pointer_required): Frame pointer is always required when
55ba61f3
JH
7488 profiling.
7489
f7e5dfbd
JH
7490Thu Oct 31 16:09:44 CET 2002 Jan Hubicka <jh@suse.cz>
7491
7492 * i386.md (negdf2_ifs_rex64): Don't allow GPR operand.
7493
ff881d52
R
7494Thu Oct 31 12:45:55 2002 J"orn Rennecke <joern.rennecke@superh.com>
7495
7496 * sh.h (binary_logical_operator): Declare.
7497 * sh.c (binary_logical_operator): New function.
7498 * sh.md (xordi3+1): New combiner splitter pattern.
7499
e8e4c876
DB
75002002-10-31 David O'Brien <obrien@FreeBSD.org>
7501
7502 * config/sparc/freebsd.h (TRANSFER_FROM_TRAMPOLINE): Define
7503 __enable_execute_stack function.
7504
4977bab6
ZW
75052002-10-30 Zack Weinberg <zack@codesourcery.com>
7506
7507 * gthr.h, gthr-dce.h, gthr-posix.h, gthr-rtems.h,
7508 gthr-solaris.h, gthr-win32.h: Remove __gthread_key_dtor.
7509 * unwind-sjlj.c (fc_key_dtor): Delete.
7510 (fc_key_init): Adjust __gthread_key_create call to match.
7511
27bd7792
AH
75122002-10-30 Aldy Hernandez <aldyh@redhat.com>
7513
7bb9f927 7514 * c-common.c: Add GTY to vector_type_node_list.
27bd7792 7515
a02aa5b0
JDA
75162002-10-30 John David Anglin <dave@hiauly.hia.nrc.ca>
7517
7518 * pa-linux.h (ASM_OUTPUT_EXTERNAL_LIBCALL): Define.
7519 * pa-protos.h (attr_length_millicode_call, attr_length_call,
7520 pa_init_machine_status): Declare new global functions.
7521 * pa.c (void copy_fp_args, length_fp_args, get_plabel): Declare and
7522 implement new functions.
7523 (attr_length_millicode_call, attr_length_call): Implement.
7524 (total_code_bytes): Change type to long.
7525 (pa_output_function_prologue): Compute total_code_bytes on TARGET_64BIT.
7526 Reset counter if flag_function_sections.
7527 (output_deferred_plabels): Set output alignment to 3 for TARGET_64BIT.
7528 (output_cbranch): Move call to gen_label_rtx.
7529 (output_millicode_call): Rewrite adding long TARGET_64BIT call, expose
7530 delay slot in all variants, shorten pc-relative calls.
7531 (output_call): Rewrite adding long TARGET_64BIT call, improved delay
7532 slot usage and exposure, various new call variants, and shortened
7533 sequences for some variants on TARGET_PA_20.
7534 Miscellaneous format changes.
7535 * pa.h (total_code_bytes): Change type to long.
7536 (MASK_LONG_CALLS, TARGET_LONG_CALLS, TARGET_LONG_ABS_CALL,
7537 TARGET_LONG_PIC_SDIFF_CALL, TARGET_LONG_PIC_PCREL_CALL): Define.
7538 (TARGET_SWITCHES): Add "-mlong-calls" and "-mno-long-calls" options.
7539 (EXTRA_CONSTRAINT, GO_IF_LEGITIMATE_ADDRESS,
7540 LEGITIMIZE_RELOAD_ADDRESS): Don't use long floating point loads and
7541 stores on TARGET_ELF32.
7542 *pa.md (define_delay): Allow insns in delay on TARGET_PORTABLE_RUNTIME.
7543 (unnamed patterns for mulsi3, divsi3, udivsi3, modsi3, umodsi3 and
7544 canonicalize_funcptr_for_compare expanders): Calculate attribute length
7545 attr_length_millicode_call().
7546 (call_internal_symref, call_value_internal_symref): Clobber register 1.
7547 Calculate attribute length using attr_length_call().
7548 (call_internal_reg_64bit, call_value_internal_reg_64bit): Move gp load
7549 to delay slot.
7550 (sibcall, sibcall_value): Rewrite.
7551 (sibcall_internal_symref, sibcall_value_internal_symref): Clobber
7552 register 1. Use attr_length_call().
7553 (sibcall_internal_symref_64bit, sibcall_value_internal_symref_64bit):
7554 New patterns.
7555 (unamed pattern for canonicalize_funcptr_for_compare): Rewrite.
7556 * som.h (MEMBER_TYPE_FORCES_BLK): Define.
7557 * t-pa64 (TARGET_LIBGCC2_CFLAGS): Add "-mlong-calls".
7558 * doc/invoke.texi (mlong-calls): Document.
7559
9402f6fb
RS
75602002-10-30 Roger Sayle <roger@eyesopen.com>
7561
7562 * fold-const.c (fold_binary_op_with_conditional_arg): Improve
7563 handling of cases where one or both branches of the conditional
7564 have void type, i.e. throw an exception or don't return.
7565 (fold): Only apply (and undo) type conversion to the non-void
7566 branches of a COND_EXPR.
7567
9b5b7e3a
MM
75682002-10-30 Mark Mitchell <mark@codesourcery.com>
7569
7570 PR c++/8333
7571 * varasm.c (asm_output_aligned_bss): Do not call
7572 ASM_GLOBALIZE_LABEL.
7573
df7a8989
DE
75742002-10-30 David Edelsohn <edelsohn@gnu.org>
7575 Torbjorn Granlund <tege@swox.com>
7576
7577 * config/rs6000/rs6000.md (load_toc_v4_PIC_1): Use preferred form
7578 for addressibility.
7579 (load_toc_v4_PIC_1b): Same.
7580
d2d199a3
KH
75812002-10-30 Kazu Hirata <kazu@cs.umass.edu>
7582
7583 * config/h8300/h8300.c (h8300_eightbit_constant_address_p):
7584 Truncate the addresses for H8/300 using HImode.
7585
4977bab6
ZW
7586Tue Oct 29 23:28:10 CET 2002 Jan Hubicka <jh@suse.cz>
7587
7588 * i386.md (negdf splitter): Fix construction of the constant.
7589
7590Tue Oct 29 20:47:06 CET 2002 Jan Hubicka <jh@suse.cz>
7591
7592 * i386.md (negsf, negdf): Reorganize to use vector modes
7593 for SSE variants.
7594 (abssf, absdf): Use force_reg.
7595 (movv4sf, movv2df): New splitters.
7596 * i386.h (PREDICATE_CODES): add zero_extended_scalar_load_operand
7597 * i386.c (zero_extended_scalar_load_operand
7598
7599 * i386-protos.h (ix86_expand_call): Update prototype.
7600 * i386.c (ix86_function_ok_for_sibcall): Handle 64bit
7601 (ix86_expand_call): Use r11 for indirect sibcalls.
7602 * i386.md (call, call_value, untyped_call, call_value_pop):
7603 update x86_expand_call call.
7604 (sibcall, sibcall_value): new patterns
7605 (call_rex64, call_value_rex64): Do not accept sibcalls.
7606 (sibcall_rex64, sibcall_value_rex64,
7607 sibcall_rex64_v, sibcall_value_rex64_v): New.
7608
7609Tue Oct 29 15:37:39 CET 2002 Jan Hubicka <jh@suse.cz>
7610
7611 * toplev.c (rest_of_compilation): Reorganize way reg_scan is called
7612 before final pass.
7613
33c21f5c
HPN
76142002-10-29 Hans-Peter Nilsson <hp@bitrange.com>
7615
7616 * toplev.c (rest_of_type_compilation): Return early in case of
7617 errors.
7618 (check_global_declarations): Don't call debug_hooks->global_decl
7619 in case of errors.
7620
d1445f8d
AB
76212002-10-28 Andreas Bauer <baueran@in.tum.de>
7622
7623 * doc/c-tree.texi (Tree overview): Fix typos.
7624
fc556cb9
PE
76252002-10-29 Phil Edwards <pme@gcc.gnu.org>
7626
7627 * Makefile.in (gnucompare*): Only record bad comparisons
7628 if there really was a bad comparison.
7629
f8ca7923
JH
7630Tue Oct 29 19:32:16 CET 2002 Jan Hubicka <jh@suse.cz>
7631
7632 * i386.h (CONST_DOUBLE_OK_FOR_LETTER_P): Remove 'H'
7633 * i386.md (movsf*, movdf*): Use 'C' instead of 'H'
7634 * md.texi (machine dependent constraints): Document 'C'
7635
7636 * simplify-rtx.c (simplify_subreg): Fix const_int->vector subregging.
7637
7638 * i386.c (ix86_expand_vector_move): Fix.
7639
7640 * i386.c (ix86_expand_builtin): Use sse2_maskmovdqu_rex64.
7641 * i386.md (sse2_maskmovdqu_rex64): New pattern
7642
7643 PR target/8322
7644 * xmmintrin.h (_mm_stream_pi, _mm_stream_pd): Fix cast.
7645 (ix86_init_mmx_sse_builtins): Fix type.
7646
c95d07f8
JT
76472002-10-29 Jason Thorpe <thorpej@wasabisystems.com>
7648
7649 * gthr-posix.h: Include <unistd.h> for feature tests.
7650 (sched_get_priority_max, sched_get_priority_min)
7651 (pthread_getschedparam, pthread_setschedparam): Only use
7652 if _POSIX_THREAD_PRIORITY_SCHEDULING is defined.
272d0bee 7653 (__gthread_objc_thread_set_priority): Don't treat all nonzero
c95d07f8
JT
7654 returns from sched_get_priority_max and sched_get_priority_min
7655 as an error.
7656
3950794d
KH
76572002-10-29 Kazu Hirata <kazu@cs.umass.edu>
7658
7659 * config/h8300/h8300.h (TARGET_DEFAULT): Make it
7660 MASK_QUICKCALL.
7661
803d56f5
KH
76622002-10-29 Kazu Hirata <kazu@cs.umass.edu>
7663
7664 * config/h8300/h8300.c (h8300_eightbit_constant_address_p): New.
7665 (h8300_tiny_constant_address_p): Likewise.
7666 * config/h8300/h8300.h (EIGHTBIT_CONSTANT_ADDRESS_P): Use
7667 h8300_eightbit_constant_address_p.
7668 (TINY_CONSTANT_ADDRESS_P): Use h8300_tiny_constant_address_p.
7669 * config/h8300/h8300-protos.h: Add the prototypes for the two
7670 new functions.
7671
6bb8a3f7
KH
76722002-10-29 Kazu Hirata <kazu@cs.umass.edu>
7673
7674 * reload1.c (update_eliminables): Unconditionally check if
7675 frame_pointer_needed has changed.
7676
fc8dfa20
JH
7677Tue Oct 29 15:37:39 CET 2002 Jan Hubicka <jh@suse.cz>
7678
7679 * toplev.c (rest_of_compilation): Reorganize way reg_scan is called
7680 before final pass.
7681
6e7727eb
EB
76822002-10-29 Eric Botcazou <ebotcazou@libertysurf.fr>
7683
a5163dcd 7684 PR optimization/8334
7bb9f927
ZW
7685 * expr.c (expand_expr) [PLUS]: Don't use simplify_binary_operation;
7686 check for zero operands explicitly.
6e7727eb 7687
02c6a17a
RS
76882002-10-29 Richard Sandiford <rsandifo@redhat.com>
7689
7690 * config/mips/mips.md (extv, extzv, insv): Set size of referenced
7691 memory after adjusting to BLKmode.
7692
1862869d
KH
76932002-10-29 Kazu Hirata <kazu@cs.umass.edu>
7694
7695 * config/h8300/h8300.h (MASK_*): New.
7696 (TARGET_*): Use MASK_*.
7697
4977bab6
ZW
76982002-10-28 Zack Weinberg <zack@codesourcery.com>
7699
7700 * config.gcc (*-*-vxworks, powerpc-wrs-vxworks*): New stanzas.
7701 * config/t-vxworks, config/vxworks.h, config/rs6000/t-vxworks,
7702 config/rs6000/vxworks.h: New files.
7703 * config/rs6000/sysv4.h: Rip out -mvxworks and all related code.
7704
7705 * config.gcc (alpha*-*-vxworks*, arm-*-vxworks*,
7706 i?86-wrs-vxworks*, i960-wrs-vxworks* [all],
7707 m68k-wrs-vxworks*, mips-wrs-vxworks, powerpc-wrs-vxworks*,
7708 powerpcle-wrs-vxworks*, sparc*-wrs-vxworks* [all],
7709 sparc-*-vxsim*): Delete stanzas.
7710 * gthr-vxworks.h: Rip out all substantive code and just
7711 include gthr-single.h.
7712
7713 * config/alpha/vxworks.h, config/arm/vxarm.h,
7714 config/i386/vxi386.h, config/i960/t-vxworks960,
7715 config/i960/vx960-coff.h, config/i960/vx960.h,
7716 config/m68k/t-vxworks68, config/m68k/vxm68k.h,
7717 config/mips/vxworks.h, config/rs6000/vxppc.h,
7718 config/sparc/t-vxsparc, config/sparc/t-vxsparc64,
7719 config/sparc/vxsim.h, config/sparc/vxsparc.h,
7720 config/sparc/vxsparc64.h: Delete files.
7721
ee3c755a
JT
77222002-10-28 Jason Thorpe <thorpej@wasabisystems.com>
7723
7724 * config.gcc (*-*-netbsd*): Add NETBSD_ENABLE_PTHREADS to
7725 tm_defines if pthreads are enabled.
7726 * config/netbsd.h (LIB_SPEC): Only support the -pthread option
7727 if NETBSD_ENABLE_PTHREADS is defined.
7728
423adbb9
KH
77292002-10-28 Kazu Hirata <kazu@cs.umass.edu>
7730
7731 * ChangeLog.1: Fix typos.
7732 * cse.c: Fix a comment typo.
7733 * reload1.c: Likewise.
7734
d7521977
HPN
77352002-10-27 Hans-Peter Nilsson <hp@bitrange.com>
7736
7737 * fixinc/inclhack.def (libc1_G_va_list): Correct test_text.
7738 * fixinc/tests/base/_G_config.h: New file.
7739
3eae4643
KH
77402002-10-27 Kazu Hirata <kazu@cs.umass.edu>
7741
7742 * combine.c: Fix comment formatting.
7743 * loop.c: Likewise.
7744 * real.c: Likewise.
7745 * regclass.c: Likewise.
7746 * regmove.c: Likewise.
7747 * regrename.c: Likewise.
7748 * reg-stack.c: Likewise.
7749 * reload1.c: Likewise.
7750 * reload.c: Likewise.
7751 * reload.h: Likewise.
7752 * unroll.c: Likewise.
7753
e591c83d
KH
77542002-10-27 Kazu Hirata <kazu@cs.umass.edu>
7755
7756 * reload1.c (reload): Fix a comment typo.
7757
a0ba837e
JH
7758Sun Oct 27 10:15:24 CET 2002 Jan Hubicka <jh@suse.cz>
7759
7760 * linux64.h (DEFAULT_PCC_STRUCT_RETURN): Define.
7761
cc0017a9
ZD
77622002-10-27 Zdenek Dvorak <rakdver@atrey.karlin.mff.cuni.cz>
7763
7764 * Makefile.in (dwarf2out.o): Add dependendcy on hashtab.h.
7765 * dwarf2out.c: Include hashtab.h.
7766 (is_main_source): New static variable.
7767 (attr_checksum, die_checksum): Modified to handle die references.
7768 (same_loc_p, same_dw_val_p, same_attr_p, same_die_p, same_die_p_wrap,
7769 unmark_all_dies, htab_cu_hash, htab_cu_eq, htab_cu_del, check_duplicate_cu,
7770 record_comdat_symbol_number): New static functions.
7771 (output_comp_unit, compute_section_prefix, is_type_die, break_out_includes,
7772 mark_dies, unmark_dies, dwarf2out_start_source_file): Modified.
7773 * toplev.c (rest_of_decl_compilation): Call of dwarf2out_decl for type
7774 declarations added.
7775
d7af42bc
KH
77762002-10-26 Kazu Hirata <kazu@cs.umass.edu>
7777
7778 * config/h8300/h8300.c (initial_offset): Change to
7779 h8300_initial_elimination_offset.
7780 * config/h8300/h8300.h (INITIAL_ELIMINATION_OFFSET): Use
7781 h8300_initial_elimination_offset.
7782 * config/h8300/h8300-protos.h: Update the prototype.
7783
7e5037dc
HPN
77842002-10-26 Hans-Peter Nilsson <hp@bitrange.com>
7785
4b32269b
HPN
7786 * config/mmix/mmix.h (LIBCALL_VALUE): Use
7787 MMIX_RETURN_VALUE_REGNUM, not MMIX_OUTGOING_RETURN_VALUE_REGNUM.
7788 (FUNCTION_VALUE_REGNO_P): Similar, but move code to...
7789 * config/mmix/mmix.c (mmix_function_value_regno_p): New.
7790 * config/mmix/mmix-protos.h: Remove needless ifdefs on TREE_CODE
7791 and RTX_CODE.
7792 (mmix_function_value_regno_p): Declare.
7793
7e5037dc
HPN
7794 * config/mmix/mmix.md ("fixuns_truncdfdi2"): Replace unsigned_fix,
7795 invalid for floating point mode result, with fix.
7796
4977bab6
ZW
7797Fri Oct 25 00:04:21 2002 Alexandre Oliva <aoliva@redhat.com>
7798
7799 * Makefile.in (GCC_FOR_TARGET): Add -L$(objdir)/../ld.
7800 (STAGE2_FLAGS_TO_PASS): Pass GCC_FOR_TARGET.
7801 (stage1_build): Likewise.
7802
94c1e0e8
MS
78032002-10-25 Mike Stump <mrs@apple.com>
7804
da89b956 7805 Fixes gcc.dg/warn-1.c.
4977bab6
ZW
7806 * c-typeck.c (warn_for_assignment): Don't print argument number,
7807 if zero.
94c1e0e8 7808
0fb53e68
JH
7809Sat Oct 26 01:44:46 CEST 2002 Jan Hubicka <jh@suse.cz>
7810
7811 * toplev.c (dump_file_index): Add DFI_ce3.
7812 (dump_file_info): Likewise.
7813 (rest_of_compilation): Run first ifcvt pass before tracer.
7814
794186ca
SE
78152002-10-25 Steve Ellcey <sje@cup.hp.com>
7816
7817 * config/ia64/hpux.h (BITS_BIG_ENDIAN): Remove.
7818
cd60b4b8
RH
78192002-10-25 Richard Henderson <rth@redhat.com>
7820
7821 * real.c (real_to_decimal): If the >1 tens reduction loop results
7822 in a negative exponent, fall into the <1 pten computation.
7823
f3763a44
ZW
78242002-10-25 Zack Weinberg <zack@codesourcery.com>
7825
7826 PR middle-end/6994
7827 * c-objc-common.c (inline_forbidden_p): Can not inline
7828 functions containing structures or unions containing VLAs.
7829 * tree-inline.c (walk_tree): For all class 't' nodes, walk
7830 TYPE_SIZE and TYPE_SIZE_UNIT.
7831 (copy_tree_r): Copy types if they are variably modified.
7832
8c40b097
UW
78332002-10-25 Ulrich Weigand <uweigand@de.ibm.com>
7834
7835 * config/s390/s390.md: Remove old-style peepholes.
7836
522ec94e
UW
78372002-10-25 Ulrich Weigand <uweigand@de.ibm.com>
7838
7839 * config/s390/s390.c (s390_decompose_address): Do not range check the
7840 displacement if base or index is the argument pointer register.
7841
a7475ab1
HPN
78422002-10-24 Hans-Peter Nilsson <hp@bitrange.com>
7843
85c87994
HPN
7844 PR other/3337
7845 PR bootstrap/6763
7846 PR bootstrap/8122
a7475ab1
HPN
7847 * fixinc/inclhack.def (libc1_G_va_list): New fix.
7848 * fixinc/fixincl.x: Regenerate.
7849 * config/i386/linux.h: Move MD_FALLBACK_FRAME_STATE_FOR inside
7850 ifndef IN_LIBGCC2. Wrap it together with signal.h and
7851 sys/ucontext.h inclusion in ifndef USE_GNULIBC_1.
7852 * configure.in (gcc_AC_CHECK_DECLS): Check vasprintf too.
7853 * config.in, configure: Regenerate.
7854
7a360cce
IS
78552002-10-24 Igor Shevlyakov <igor@microunity.com>
7856
7bb9f927 7857 * varasm.c (struct rtx_const): Array size 16 for V16QImode.
7a360cce 7858
fcbe3b89
RH
78592002-10-24 Richard Henderson <rth@redhat.com>
7860
7861 * config/i386/i386.c (x86_output_mi_thunk): Fix x86_64 pic jump.
7862
1a86c850
KH
78632002-10-24 Kazu Hirata <kazu@cs.umass.edu>
7864
7865 * config/h8300/h8300.c (initial_offset): Simplify by using
7866 round_frame_size.
7867
de7999ba
MM
78682002-10-24 Marek Michalkiewicz <marekm@amelek.gda.pl>
7869
7870 * doc/install.texi (avr): Update required binutils version.
7871
78722002-10-24 Theodore A. Roth <troth@openavr.org>
7873
7874 * doc/install.texi: Point avr users at more up-to-date information.
7875
84817c5d
UW
78762002-10-24 Ulrich Weigand <uweigand@de.ibm.com>
7877
7878 * config/s390/s390.md (movdi, movsi, movhi, movqi): Add peepholes2
7879 to pull operands out of the literal pool where possible.
7880
d0749053
DC
78812002-10-24 Denis Chertykov <denisc@overta.ru>
7882
7883 * config/avr/avr.c (init_cumulative_args): Test fntype for zero.
7884
37d0b254
SE
78852002-10-24 Steve Ellcey <sje@cup.hp.com>
7886
7887 * expr.c (convert_move): If unsignedp is less then zero there
7888 is no equivalent code.
7889
7af907e9
ZW
78902002-10-24 Zack Weinberg <zack@codesourcery.com>
7891
7892 * tree.def: Delete mention of nonexistent ARRAY_TYPE fields.
7893
862a2d83
UW
78942002-10-24 Ulrich Weigand <uweigand@de.ibm.com>
7895
7af907e9 7896 * config/s390/s390.h: Rework comments; re-sort target macro definitions
862a2d83
UW
7897 according to the sequence they are defined in the manual.
7898 (POINTER_BOUNDARY): Remove.
7899
489eda65
KH
79002002-10-24 Kazu Hirata <kazu@cs.umass.edu>
7901
7902 * config/h8300/h8300.c (round_frame_size): Replace 8 with
7903 BITS_PER_UNIT.
7904
2ba08201
KH
79052002-10-24 Kazu Hirata <kazu@cs.umass.edu>
7906
7907 * config/h8300/h8300.h (EIGHTBIT_CONSTANT_ADDRESS_P): Make it
7908 64-bit safe.
7909 (TINY_CONSTANT_ADDRESS_P): Likewise.
7910
5f13cfc6
RH
79112002-10-24 Richard Henderson <rth@redhat.com>
7912
7913 * config/ia64/ia64.c (TARGET_ASM_CAN_OUTPUT_MI_THUNK): True.
7914 (ia64_output_mi_thunk): Rewrite to use rtl, and to handle the
7915 vcall offset.
7916
3bd216f2
RH
79172002-10-24 Richard Henderson <rth@redhat.com>
7918
7af907e9
ZW
7919 PR opt/7944
7920 * reload.c (find_reloads_toplev): Mode of X is not important
3bd216f2
RH
7921 when simplifying subregs of constants.
7922
60bc2b4b
RS
79232002-10-24 Richard Sandiford <rsandifo@redhat.com>
7924
7925 * config.gcc (mips64vr-*-elf*, mips64vrel-*-elf*): Add
7926 MIPS_MARCH_CONTROLS_SOFT_FLOAT=1 to $tm_defines.
7927 * config/mips/mips.c (MIPS_MARCH_CONTROLS_SOFT_FLOAT): Default to 0.
7928 (override_options): Base default setting of MASK_SOFT_FLOAT on -march
7929 if MIPS_MARCH_CONTROLS_SOFT_FLOAT.
7930
5be5c8d4
RS
79312002-10-24 Richard Sandiford <rsandifo@redhat.com>
7932
7933 * optabs.c (expand_binop): Don't reuse the shift target in the
7934 middle of shift sequences.
7935
4977bab6
ZW
7936Wed Oct 23 22:48:44 CEST 2002 Jan Hubicka <jh@suse.cz>
7937
7938 * i386.md (abs splitters): Do not produce nested subregs.
7939
7940Wed Oct 23 12:42:32 CEST 2002 Jan Hubicka <jh@suse.cz>
7941
7942 * i386.md (movti_rex64): Fix constraints.
7943
7944Wed Oct 23 12:01:21 CEST 2002 Jan Hubicka <jh@suse.cz>
7945
7946 * i386.md (abssf,absdf): Use vector operands for SSE
7947 (abssf2_ifs, absdf2_ifs, absdf2_ifs_rex64 and splitters): Update for
7948 vector operand.
7949
196e1ae3
ZL
79502002-10-23 Ziemowit Laski <zlaski@apple.com>
7951
7952 * objc/objc-act.c (get_static_reference): Remove unneeded
7953 TYPE_BINFO initialization.
7954 (get_object-reference): Likewise.
7955 (build_constructor): Tighten precondition check.
7956 (finish_message_expr): Likewise.
7957
8bfb45f8
JJ
79582002-10-23 Jakub Jelinek <jakub@redhat.com>
7959
7960 * config/i386/i386.c (local_symbolic_operand): Move LABEL_REF test
7961 after CONST test.
7962
16448fd4
SE
79632002-10-23 Steve Ellcey <sje@cup.hp.com>
7964
7965 * config/ia64/ia64.c (hfa_element_mode): Don't allow 128 bit floats
7966 in HFAs.
7967
e2358068
RH
79682002-10-23 Richard Henderson <rth@redhat.com>
7969
7970 * config/alpha/alpha.c (TARGET_ASM_CAN_OUTPUT_MI_THUNK): True.
7971 (alpha_output_mi_thunk_osf): Handle vcall_offset.
7972
8bcefb43
ZW
79732002-10-23 Zack Weinberg <zack@codesourcery.com>
7974
7975 * langhooks.h (struct lang_hooks_for_tree_inlining): Add
7976 var_mod_type_p.
7977 * langhooks-def.h: Default for tree_inlining.var_mod_type_p is
7978 hook_tree_bool_false.
7979
7980 * tree.c (variably_modified_type_p): Moved here from
7981 cp/tree.c. Use lang_hooks.tree_inlining.var_mod_type_p for
7982 language-specific cases. Due to this, must weaken some 'if
7983 and only if' checks to merely 'if'.
7984 * tree.h: Prototype variably_modified_type_p.
7985
7986 * tree-inline.c (walk_tree): #undef WALK_SUBTREE_TAIL at end.
7987
8e509cf9
UW
79882002-10-23 Ulrich Weigand <uweigand@de.ibm.com>
7989
7990 * config/s390/linux.h (CC1_SPEC, CC1PLUS_SPEC): Remove.
7991 * config/s390/s390.c (optimization_options): Disable -fcaller-saves.
7992
7993 * config/s390/s390-protos.h (fp_operand): Remove.
7994 * config/s390/s390.c (fp_operand): Remove.
7995 * config/s390/s390.md ("movdi"): Replace fp_operand by FP_REG_P.
7996 ("*movdi_lhi", "*movdi_lli", "*movdi_larl"): Likewise.
7997 ("movsi", "*movsi_lhi", "*movsi_lli"): Likewise.
7998 (movdi_31, movdf_31 splitters): Likewise.
8bcefb43 7999
8e509cf9
UW
8000 * config/s390/s390.h (IEEE_FLOAT): Remove.
8001 (TARGET_FLOAT_FORMAT): Define in terms of TARGET_IEEE_FLOAT.
8002 (INT_REGNO_P): Rename to ...
8003 (GENERAL_REGNO_P): ... this.
8004 (FLOAT_REGNO_P): Rename to ...
8005 (FP_REGNO_P): ... this.
8006 (ADDR_REGNO_P): New macro.
8007 (GENERAL_REG_P, ADDR_REG_P, FP_REG_P, CC_REG_P): New macros.
8008 (REGNO_OK_FOR_DATA_P, REGNO_OK_FOR_FP_P): Remove.
8009 (DATA_REG_P, FP_REG_P, ADDRESS_REG_P): Likewise.
8010 (HARD_REGNO_NREGS): Adapt to macro renaming.
8011 (HARD_REGNO_MODE_OK): Likewise.
8012
34bb030a
DE
80132002-10-23 David Edelsohn <edelsohn@gnu.org>
8014 Geoff Keating <geoffk@apple.com>
8015
8016 * config/rs6000/rs6000.c (rs6000_register_move_cost): New function.
8017 (rs6000_memory_move_cost): New function.
8018 * config/rs6000/rs6000-protos.h: Declare them.
8019 * config/rs6000/rs6000.h: Use them.
8020
1ab9ba62
UW
80212002-10-23 Ulrich Weigand <uweigand@de.ibm.com>
8022
8bcefb43 8023 * libgcc2.c (__udiv_w_sdiv): Use attribute ((always_inline)) when
1ab9ba62
UW
8024 inlining it into other libgcc2 routines.
8025 (__udivmoddi4): Likewise.
8026
4b2ece8f
NN
80272002-10-22 Nathanael Nerode <neroden@gcc.gnu.org>
8028
8029 * doc/sourcebuild.texi (Test Suites): Improve.
8030
2d173d20
SS
80312002-10-22 Stan Shebs <shebs@apple.com>
8032
8033 * config/rs6000/rs6000.c (rs6000_output_mi_thunk): Add missing
8034 case for Darwin.
8035
43146684
JW
80362002-10-22 Jim Wilson <wilson@redhat.com>
8037
8038 * config/i386/i386.md (subdi3_1): Add call to ix86_binary_operator_ok.
8039
a00782ed
JH
8040Wed Oct 23 01:52:36 CEST 2002 Jan Hubicka <jh@suse.cz>
8041
8042 PR other/8289
8043 * xmmintrin.h: Add const to the argument of loads.
8044
8045 * i386.md (pushv2di): New pattern.
8046 PR target/6890
8047 * xmmintrin.h (_MM_TRANSPOSE4_PS): New.
8048
3961e8fe
RH
80492002-10-22 Richard Henderson <rth@redhat.com>
8050
8051 * target.h (gcc_target.asm_out): Merge output_mi_thunk and
8052 output_mi_vcall_thunk into a single hook. Add can_output_mi_thunk.
8053 * target-def.h (TARGET_ASM_OUTPUT_MI_THUNK): Don't conditionalize.
8054 (TARGET_ASM_OUTPUT_MI_VCALL_THUNK): Remove.
8055 (TARGET_ASM_CAN_OUTPUT_MI_THUNK): New.
8056 (TARGET_ASM_OUT): Update.
8057 * hooks.c (hook_bool_tree_hwi_hwi_tree_false): New.
8058 (hook_bool_tree_hwi_hwi_tree_true): New.
8059 (default_can_output_mi_thunk_no_vcall): New.
8060 * hooks.h: Declare them.
8061 * system.h (ASM_OUTPUT_MI_THUNK): Poison.
8062
8063 * config/alpha/alpha.c (TARGET_ASM_CAN_OUTPUT_MI_THUNK): New.
8064 (alpha_output_mi_thunk_osf): Add VCALL_OFFSET parameter.
8065 * config/arm/arm.c, config/cris/cris.c, config/frv/frv.c,
8066 config/i960/i960.c, config/ia64/ia64.c, config/m68k/m68k.c,
8067 config/mmix/mmix.c, config/pa/pa.c, config/sparc/sparc.c,
8068 config/stormy16/stormy16.c: Similarly.
8069
8070 * config/i386/i386.c (x86_output_mi_thunk): Merge vcall_offset code.
8071 Handle 64-bit properly. Streamline.
8072 (x86_output_mi_vcall_thunk): Remove.
8073 (x86_this_parameter): Rename from ia32_this_parameter; handle 64-bit.
8074 (x86_can_output_mi_thunk): New.
8075 (TARGET_ASM_OUTPUT_MI_VCALL_THUNK): Remove.
8076 (TARGET_ASM_CAN_OUTPUT_MI_THUNK): New.
8077 (override_options): Don't zap targetm.asm_out.output_mi_vcall_thunk.
8078
8079 * config/rs6000/rs6000.c (rs6000_output_mi_thunk): Rename from
8080 output_mi_thunk; make static; always use function_section.
8081 (TARGET_ASM_OUTPUT_MI_THUNK): New.
8082 (TARGET_ASM_CAN_OUTPUT_MI_THUNK): New.
8083 (rs6000_ra_ever_killed): Test no_new_pseudos not
8084 targetm.asm_out.output_mi_thunk in conjunction with thunks.
8085 * config/rs6000/rs6000-protos.h: Update.
8086 * config/rs6000/sysv4.h (TARGET_ASM_OUTPUT_MI_THUNK): Remove.
8087 * config/rs6000/xcoff.h (ASM_DECLARE_FUNCTION_NAME): Don't call
8088 xcoffout_declare_function when using rs6000_output_mi_thunk.
8089
8bcefb43 8090 * config/s390/s390.c (s390_output_mi_thunk): Rename from
3961e8fe
RH
8091 s390_output_mi_vcall_thunk.
8092 (TARGET_ASM_OUTPUT_MI_THUNK): Remove.
8093 (TARGET_ASM_CAN_OUTPUT_MI_THUNK): New.
8094
8095 * config/vax/vax.c (vax_output_mi_thunk): Static; add vcall_offset.
8096 (TARGET_ASM_OUTPUT_MI_THUNK, TARGET_ASM_CAN_OUTPUT_MI_THUNK): New.
8097 * config/vax/vax-protos.h: Update.
8098 * config/vax/vax.h (ASM_OUTPUT_MI_THUNK): Remove.
8099
0e67d460
JH
8100Wed Oct 23 00:33:11 CEST 2002 Jan Hubicka <jh@suse,cz>
8101
8102 * i386.c (standard_sse_constant_p): Accept vector and integer zeros too.
8103 * i386.h (EXTRA_CONSTRAINT): Recognize 'C'
8104 * i386.md (movti_internal): Use 'C'
8105
8106 * xmmintrin.h (_mm_cmplt_epi*): New.
8107
d5869ca0
UW
81082002-10-22 Ulrich Weigand <uweigand@de.ibm.com>
8109
8110 * config/s390/s390.md ("*movdi_64"): Fix op_type attribute.
8111 ("*movdf_64"): Likewise.
8112 ("*lshrdi3_64"): Likewise.
8113 ("blockage"): Add length attribute.
8114 ("lit"): Likewise.
8115
680dd104
JH
8116Tue Oct 22 23:51:34 CEST 2002 Jan Hubicka <jh@suse.cz>
8117
8118 * i386.md: FIx typo.
8119 (sse2_cvtsi2sd, sse2_pslrdq): Fix template.
8120 (sse2_umulv2siv2di3): Fix predicate.
8121 (sse2_psadbw, ashrv8hi3, ashrv4si3, lshrv8hi3 lshrv4si3,
8122 lshrv2di3, ashlv8hi3, ashlv4si3, ashlv2di3): Likewise.
8123 * xmmintrin.h (_mm_mul_epu16): Rename to...
8124 (_mm_mul_epu32): This one.
8125 (_mm_cvtsi32_si128, _mm_cvtsi128_si32): New.
8126
8127 (contains_128bit_aligned_vector_p): Undo accidental checkin.
8128
3aabf9a5
EC
81292002-10-22 Eric Christopher <echristo@redhat.com>
8130
8131 * config/sparc/sparc.h: Add #error.
8132
42c78618
UW
81332002-10-22 Ulrich Weigand <uweigand@de.ibm.com>
8134
8135 * config.gcc [s390-*-linux]: Remove s390/t-linux from tmake_file.
8136 [s390x-*-linux*]: Likewise.
8137 * config/s390/t-linux: Remove.
8138 * config/s390/s390.h: Include fixdfdi.h when building libgcc2.
8139
077084dd
JH
8140Tue Oct 22 19:07:03 CEST 2002 Jan Hubicka <jh@suse.cz>
8141
8142 * i386.c (builtin_description): Add IX86_BUILTIN_PUNPCKHQDQ128.
8143 (ix86_expand_builtin): Fix MASKMOVDQU expasion.
8144 * i386.h (ix86_builtins): Add IX86_BUILTIN_PUNPCKHQDQ128.
8145 * i386.md (mmx_punpck?dq): Simplify.
8146 (sse2_pubpcklqdq): Fix.
8147 (sse2_pubpckhqdq): New.
8148 * xmmintrin.h (_mm_unpackhi_epi32): New.
8149
8150 * xmmintrin.h (_mm_cvt*, _mm_stream_pd): Fix prototypes.
8151 (_mm_shufflehi_epi16, _mm_shufflelo_epi16): Fix typo.
8152
8fe734a3
NS
81532002-10-22 Nathan Sidwell <nathan@codesourcery.com>
8154
8155 PR c++/7209
8156 * fold_const.c (fold_binary_op_with_conditional_arg): Always
8157 build compound_expr if we used save_expr.
8158
6a0a6ac4
AM
81592002-10-22 Alan Modra <amodra@bigpond.net.au>
8160
8161 * output.h (SECTION_NOTYPE): Define.
8162 * varasm.c (default_section_type_flags_1): Set SECTION_NOTYPE for
8163 init array sections.
8164 (default_elf_asm_named_section): Mind SECTION_NOTYPE.
8165 * config/arm/arm.c (arm_elf_asm_named_section): Likewise. Also
8166 merge TLS support.
8167
4977bab6
ZW
81682002-10-21 Richard Henderson <rth@redhat.com>
8169
8170 * config/i386/i386.c (ix86_function_ok_for_sibcall): Look at
8171 the function type, not the return type.
8172
5e26e5a2
RH
81732002-10-21 Richard Henderson <rth@redhat.com>
8174
8175 * real.c (sticky_rshift_significand): Return inexact, don't
8176 or it in immediately.
8177 (sub_significands): Accept incomming carry.
8178 (div_significands, rtd_divmod): Update for sub_significands change.
8179 (round_for_format): Update for sticky_rshift_significand change.
8180 (do_add): Don't involve the inexact bit in addition, do give the
8181 inexact bit as the subtraction carry-in.
8182 (encode_internal, decode_internal, real_internal_format): New.
8183 * real.h (real_internal_format): Declare.
8184
f8eef883
UW
81852002-10-21 Ulrich Weigand <uweigand@de.ibm.com>
8186
8187 * libgcc2.c: Fix __udiv_w_sdiv breakage on platforms that
8188 don't define sdiv_qrnnd.
8189
89e56fe5
KH
81902002-10-21 Kazu Hirata <kazu@cs.umass.edu>
8191
8192 * config/h8300/h8300.h (EIGHTBIT_CONSTANT_ADDRESS_P): Simplify
8193 using IN_RANGE.
8194 (TINY_CONSTANT_ADDRESS_P): Likewise.
8195
f02e1358
JH
8196Tue Oct 22 00:04:20 CEST 2002 Jan Hubicka <jh@suse.cz>
8197
8198 * i386.c (builtin_description): Add punpcklqdq and movdq2q
8199 (ix86_init_mmx_sse_builtins): Add v2di_ftype_void, di_ftype_v2di,
8200 v16qi_ftype_pchar, void_ftype_pchar_v16qi, v4si_ftype_pchar,
8201 void_ftype_pchar_v4si; Initialize __builtin_ia32_movdq2q,
8202 __builtin_ia32_loaddqa, __builtin_ia32_loaddqu, __builtin_ia32_loadd
8203 __builtin_ia32_storedqa, __builtin_ia32_storedqu, __builtin_ia32_stored
8204 __builtin_ia32_setzero128.
8205 (ix86_expand_builtin): Handle IX86_BUILTIN_CLRTI, IX86_BUILTIN_LOADDQA,
8206 IX86_BUILTIN_LOADDQU, IX86_BUILTIN_LOADD, IX86_BUILTIN_STOREDQA,
8207 IX86_BUILTIN_STOREDQU, IX86_BUILTIN_STORED, Ix86_BUILTIN_MOVQ.
8208 * i386.h (ix86_builtins): Add IX86_BUILTIN_LOADDQA, IX86_BUILTIN_LOADDQU,
8209 IX86_BUILTIN_STOREDQA, IX86_BUILTIN_STOREDQU, IX86_BUILTIN_LOADD,
8210 IX86_BUILTIN_STORED, IX86_BUILTIN_CLRTI, IX86_BUILTIN_MOVDQ2Q,
8211 IX86_BUILTIN_PUNPCKLQDQ128, Ix86_BUILTIN_MOVQ.
8212 * i386.md (sse2_punpcklqdq, sse2_movqsse2_loadd, sse2_stored,
8213 sse2_movq): New patterns.
8214 (sse2_movdqa, sse2_movdqu, sse2_movdq2q): Fix.
8215 * xmmintrin.h (_mm_load_si128, _mm_loadu_si128, _mm_loadl_epi64,
8216 _mm_store_si128, _mm_storeu_si128, _mm_storel_epi64,
8217 _mm_setzero_si128, _mm_set_epi64, _mm_set_epi32, _mm_set_epi16,
8218 _mm_set_epi8, _mm_set1_epi64, _mm_set1_epi32, _mm_set1_epi16,
8219 _mm_set1_epi8, _mm_setr_epi64, _mm_setr_epi32, _mm_setr_epi16,
8220 _mm_setr_epi8, _mm_unpacklo_epi64,_mm_set_moveq): New functions.
8221 (_mm_insert_epi16): Fix.
8222
de40e1df
DJ
82232002-10-21 Dale Johannesen <dalej@apple.com>
8224
8bcefb43 8225 * config/rs6000/rs6000.c (rs6000_reverse_condition): Handle
de40e1df
DJ
8226 unsafe math reversals correctly for RTL generation.
8227 (output_cbranch): Replace rs6000_reverse_condition call
8228 by its former definition.
8229
75d38379
JJ
82302002-10-21 Jakub Jelinek <jakub@redhat.com>
8231
8232 * config/i386/i386.c (x86_64_sign_extended_value): Add allow_rip
8233 argument. In CM_SMALL_PIC model consider SYMBOL_REFs binding locally or
8234 from constant pool or LABEL_REFs as sign extended if allow_rip.
8235 Change all +-1GB limits to +-16MB.
8236 (x86_64_general_operand, x86_64_szext_general_operand,
8237 x86_64_nonmemory_operand, x86_64_movabs_operand,
8238 x86_64_szext_nonmemory_operand, x86_64_immediate_operand,
8239 legitimate_address_p, ix86_expand_int_movcc): Update callers.
8240 (local_symbolic_operand): Don't allow offsets bigger than +-16MB
8241 in CM_SMALL_PIC model.
8242 (legitimate_pic_address_disp_p): Don't check offsets before
8243 calling local_symbolic_operand.
8244 (legitimize_pic_address): Force offsets bigger than +-16MB into
8245 register.
8246 * config/i386/i386.h (EXTRA_CONSTRAINT, CONST_COSTS): Likewise.
8247 * config/i386/i386-protos.h (x86_64_sign_extended_value): Update
8248 prototype.
8249
8250 * configure.in: Test for @GOTNTPOFF and @INDNTPOFF on IA-32 too.
8251 Add x86-64 test. Set tls_first_minor to 14 on IA-32 and x86-64.
8252 * configure: Rebuilt.
8253 * config/i386/i386.c (x86_64_sign_extended_value): Don't allow TLS
8254 SYMBOL_REFs unless enclosed in UNSPEC. Handle UNSPEC_DTPOFF,
8255 UNSPEC_GOTNTPOFF and UNSPEC_NTPOFF.
8256 (legitimate_address_p): Allow foo@dtpoff(base) even on TARGET_64BIT
8257 -fpic.
8258 (ix86_encode_section_info): Don't ever generate TLSGD or TLSLD for
8259 non-pic code if TARGET_64BIT.
8260 (legitimize_address): Generate 64-bit TLS sequences.
8261 (output_pic_addr_const): Support x86-64 TLS operators.
8262 (i386_output_dwarf_dtprel): Output 64-bit DTPOFF as .long f@DTPOFF, 0.
8263 (print_operand_address): Use %fs instead of %gs on TARGET_64BIT.
8264 Don't append (%rip) in 64-bit TLSGD and TLSLD sequences.
8265 (output_addr_const_extra): Support x86-64 TLS operators.
8266 (maybe_get_pool_constant): Handle TARGET_64BIT -fpic.
8267 (ix86_tls_get_addr): Use __tls_get_addr on TARGET_64BIT
8268 unconditionally.
8269 * config/i386/i386.md (*tls_global_dynamic_gnu): Renamed to...
8270 (*tls_global_dynamic_32_gnu): ..., add !TARGET_64BIT.
8271 (*tls_global_dynamic_sun): Renamed to...
8272 (*tls_global_dynamic_32_sun): ..., add !TARGET_64BIT.
8273 (tls_global_dynamic): Renamed to...
8274 (tls_global_dynamic_32): ... this.
8275 (tls_global_dynamic_64, *tls_global_dynamic_64): New.
8276 (*tls_local_dynamic_base_dynamic_gnu): Renamed to...
8277 (*tls_local_dynamic_base_dynamic_32_gnu): ..., add !TARGET_64BIT.
8278 (*tls_local_dynamic_base_dynamic_sun): Renamed to...
8279 (*tls_local_dynamic_base_dynamic_32_sun): ..., add !TARGET_64BIT.
8280 (tls_local_dynamic_base_dynamic): Renamed to...
8281 (tls_local_dynamic_base_dynamic_32): ... this.
8282 (tls_local_dynamic_base_dynamic_64,
8283 *tls_local_dynamic_base_dynamic_64): New.
8284 (*tls_local_dynamic_once): Renamed to...
8285 (*tls_local_dynamic_32_once): ... this.
8286
59798a0c
UW
82872002-10-21 Ulrich Weigand <uweigand@de.ibm.com>
8288
8289 * libgcc2.c: Inline __udiv_w_sdiv when compiling __udivdi3,
8290 __divdi3, __umoddi3, or __moddi3.
8291
97d05bfd
UW
82922002-10-21 Ulrich Weigand <uweigand@de.ibm.com>
8293
8294 * c-opts.c (missing_arg): Use cl_options[opt_index].opt_code
8295 instead of just opt_index as switch expression.
8296
8297 * calls.c (store_one_arg): Change type of 'excess_align'
8298 to unsigned int.
8299
8300 * profile.c (output_gcov_string): Change type of 'temp'
8301 to size_t.
8302
5d4d885c
UW
83032002-10-21 Ulrich Weigand <uweigand@de.ibm.com>
8304
8305 * config/s390/fixdfdi.h (__fixunsdfdi, __fixdfdi): Add prototypes.
8306 (__fixunssfdi, __fixsfdi): Likewise.
8307 * config/s390/s390.c (s390_single_hi): Initialize 'value'.
8308 (s390_single_qi): Likewise.
8309 (s390_emit_epilogue): Initialize 'offset'. Remove signed vs.
8310 unsigned comparison warning.
8311 (s390_return_addr_rtx): New function.
8312 * config/s390/s390-protos.h (s390_return_addr_rtx): Declare it.
8313 * config/s390/s390.h (RETURN_ADDR_RTX): Use it.
8314 (HARD_REGNO_MODE_OK): Rewrite condition to silence warnings.
8315
3062825f
UW
83162002-10-21 Ulrich Weigand <uweigand@de.ibm.com>
8317
8318 * config/s390/s390.c (s390_output_mi_vcall_thunk): New function.
8319 (TARGET_ASM_OUTPUT_MI_VCALL_THUNK): Define target hook.
8320 (s390_output_mi_thunk): Remove.
8321 (TARGET_ASM_OUTPUT_MI_THUNK): Remove.
8322
2918c993
KH
83232002-10-21 Kazu Hirata <kazu@cs.umass.edu>
8324
8325 * config/h8300/h8300.h (N_REG_CLASSES): Parenthesize.
8326
4977bab6
ZW
83272002-10-20 Zack Weinberg <zack@codesourcery.com>
8328
8329 * config/i386/i386.c (ix86_function_ok_for_sibcall): Fix an
8330 inverted test in the conditional determining the possibility
8331 of sibcalls in PIC mode.
8332
c590b625
RH
83332002-10-20 Richard Henderson <rth@redhat.com>
8334
8335 * target.h (struct gcc_target): Line wrap.
8336
8337 * config/alpha/alpha.c (alpha_output_mi_thunk_osf): Static.
8338 (TARGET_ASM_OUTPUT_MI_THUNK): Define here...
8339 * config/alpha/alpha.h: ... not here.
8340 * config/alpha/alpha-protos.h: Update.
8341
8342 * config/arm/arm.c, config/arm/arm.h, config/arm/arm-protos.h
8343 config/cris/cris-protos.h, config/cris/cris.c, config/cris/cris.h,
8344 config/frv/frv-protos.h, config/frv/frv.c, config/frv/frv.h,
8345 config/i386/i386-protos.h, config/i386/i386.c, config/i386/openbsd.h,
8346 config/i386/unix.h, config/i960/i960-protos.h, config/i960/i960.c,
8347 config/i960/i960.h, config/ia64/ia64-protos.h, config/ia64/ia64.c,
8348 config/ia64/ia64.h, config/m68k/linux.h, config/m68k/m68k-protos.h,
8349 config/m68k/m68k.c, config/m68k/netbsd-elf.h, config/m68k/openbsd.h,
8350 config/mmix/mmix-protos.h, config/mmix/mmix.c, config/mmix/mmix.h,
3aabf9a5 8351 config/pa/pa-protos.h, config/pa/pa.c, config/pa/pa.h,
c590b625
RH
8352 config/s390/s390-protos.h, config/s390/s390.c, config/s390/s390.h,
8353 config/sparc/openbsd.h, config/sparc/sparc-protos.h,
8354 config/sparc/sparc.c, config/sparc/sparc.h,
8355 config/stormy16/stormy16-protos.h, config/stormy16/stormy16.c,
8356 config/stormy16/stormy16.h: Similarly.
8357
8358 * config/m68k/m68k.c (m68k_output_mi_thunk): Replicate mnemonic
8359 selection logic from call patterns.
8360
16f7d029
MM
83612002-10-20 Mark Mitchell <mark@codesourcery.com>
8362
8363 * config/m68k/m68k.c (m68k_output_mi_thunk): Fix typo.
8364
ab3146fd
ZD
83652002-10-20 Zdenek Dvorak <rakdver@atrey.karlin.mff.cuni.cz>
8366
8367 PR other/8202
8368 * i386.c (ix86_init_mmx_sse_builtins, ix86_expand_builtin): Define and
8369 expand __builtin_ia32_pslldqi128 and __builtin_ia32_psrldqi128.
8370 * i386.h (IX86_BUILTIN_PSLLDQI128, IX86_BUILTIN_PSRLDQI128): New.
8371 * xmmintrin.h (_mm_srli_si128, _mm_slli_si128): New.
8372
e03b7153
RS
83732002-10-20 Roger Sayle <roger@eyesopen.com>
8374
8375 PR c/761
8376 * toplev.c (flag_unsafe_profile_arcs): Remove.
8377 (flag_bounded_pointers): Remove.
8378 (flag_bounds_check): Correct comments.
8379 (lang_independent_options): Remove -funsafe-profile-arcs and
8380 -fbounded-pointers. Correct -fbounds-check comments.
8381
8382 * flags.h: Correct flag_schedule_interblock comments.
8383 (flag_bounded_pointers): Remove prototype.
8384 (flag_bounds_check): Correct comments.
8385
8386 * c-opts.c (c_common_init_options): No need to mark
8387 flag_bounds_check as unspecified.
8388 (c_common_post_options): And no need to set it from
8389 flag_bounded_pointers if its still unspecified.
8390
8391 * doc/invoke.texi: Fix some overfull hboxes in "make dvi".
8392 Document --version, -feliminate-dwarf-2-dups, -fno-sched-interblock,
8393 -fno-sched-spec, -fsched-spec-load, -fsched-spec-load-dangerous,
8394 -fsched-verbose=n, -fno-branch-count-reg and -fbounds-check.
8395
4977bab6
ZW
8396Sat Oct 19 22:02:28 2002 Alexandre Oliva <aoliva@redhat.com>
8397 Angela Marie Thomas <angela@releasedominatrix.com>
8398 Brendan Kehoe <brendan@zen.org>
8399 Nick Clifton <nickc@redhat.com>
8400 Andrew Haley <aph@redhat.com>
8401
8402 * configure.in (--with-sysroot): New. Don't inhibit libc if
8403 given. AC_SUBST TARGET_SYSTEM_ROOT, TARGET_SYSTEM_ROOT_DEFINE
8404 and CROSS_SYSTEM_HEADER_DIR.
8405 * configure: Rebuilt.
8406 * Makefile.in (CROSS_SYSTEM_HEADER_DIR): Set in configure.
8407 (TARGET_SYSTEM_ROOT): New.
8408 (DRIVER_DEFINES): Define CROSS_INCLUDE_DIR from
8409 CROSS_SYSTEM_HEADER_DIR.
8410 (install-gcc-tooldir): New target.
8411 (stmp-fixinc): Do not create $(libsubdir), but rather bail out
8412 if SYSTEM_HEADER_DIR does not exist and it's not the default
8413 sys-include directory.
8414 (deduced.h, stmp-fixproto): Quote SYSTEM_HEADER_DIR properly.
8415 (install-mkheaders): Likewise.
8416 * gcc.c (target_system_root): New variable.
8417 (add_sysrooted_prefix): New function.
8418 (process_command): Recompute run-time target_system_root from
8419 gcc_exec_prefix, keeping it unchanged if the relocated sysroot
8420 does not exist.
8421 (do_spec_1): Process 'R' spec.
8422 (main): Add md_exec_prefix to exec_prefixes regardless of
8423 startfile_prefix_spec. Use add_sysrooted_prefix for
8424 startfile_prefixes, and don't skip the default ones when cross
8425 compiling with sysroot enabled. Removed unused case of
8426 non-absolute standard_startfile_prefix.
8427 * config/interix.h: Remove the only potential, yet disabled,
8428 occurrence of non-absolute (empty) standard_startfile_prefix.
8429 * config/sh/linux.h (LIB_SPEC): Add -rpath-link in non-static
8430 linking.
8431 * config/mips/linux.h (LIB_SPEC): Define as in sh/linux.h.
8432 * doc/install.texi (--with-sysroot): Document.
8433 (--with-headers, --with-libs): Deprecate.
8434
eb0424da 84352002-10-19 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
8bcefb43 8436 Mark Mitchell <mark@codesourcery.com>
eb0424da
MM
8437
8438 * alpha-protos.h (alpha_output_mi_thunk_osf): Update signature to
8439 match target.h.
8440 * arm-protos.h, arm.c (arm_output_mi_thunk): Likewise.
8441 * cris-protos.h, cris.c (cris_asm_output_mi_thunk): Likewise.
8442 * frv-protos.h, frv.c (frv_asm_output_mi_thunk): Likewise.
8443 * i386-protos.h, i386.c (x86_output_mi_vcall_thunk,
8444 x86_output_mi_thunk): Likewise.
8445 * i960-protos.h, i960.c (i960_output_mi_thunk): Likewise.
8446 * ia64-protos.h, ia64.c (ia64_output_mi_thunk): Likewise.
8447 * m68k-protos.h, m68k.c (m68k_output_mi_thunk): Likewise.
8448 * mmix-protos.h, mmix.c (mmix_asm_output_mi_thunk): Likewise.
8449 * rs6000-protos.h, rs6000.c (output_mi_thunk): Likewise.
8450 * s390-protos.h, s390.c (s390_output_mi_thunk): Likewise.
8451 * stormy16-protos.h, stormy16.c (xstormy16_asm_output_mi_thunk):
8452 Likewise.
8453 * vax-protos.h, vax.c (vax_output_mi_thunk): Likewise.
3aabf9a5 8454
eb0424da
MM
8455 * target.h (gcc_target): Update output_mi_thunk and
8456 output_mi_vcall_thunk to take a HOST_WIDE_INT delta and
8457 vcall_index.
8458
8459 * config/alpha/alpha.c: Replace ASM_OUTPUT_MI_THUNK with
8460 TARGET_ASM_OUTPUT_MI_THUNK in comments.
8461 * config/alpha/vms.h (ASM_OUTPUT_MI_THUNK): Don't #undef it.
8462 (TARGET_ASM_OUTPUT_MI_THUNK): #undef it.
8463 * config/frv/frv.h (DEFAULT_VTABLE_THUNKS): Remove definition.
8464 * config/i386/i386-protos.h (x86_output_mi_vcall_thunk): Update
8465 signature.
8466 * config/i386/i386.c (x86_output_mi_vcall_thunk): Likewise.
8467 * config/i386/openbsd.h: Replace ASM_OUTPUT_MI_THUNK with
8468 TARGET_ASM_OUTPUT_MI_THUNK in comments.
8469 * config/i960/i960.h (ASM_OUTPUT_MI_THUNK): Don't define.
8470 (TARGET_ASM_OUTPUT_MI_THUNK): Do define.
8471 * config/m68k/openbsd.h: Replace ASM_OUTPUT_MI_THUNK with
8472 TARGET_ASM_OUTPUT_MI_THUNK in comments.
8473 * config/rs6000/rs6000.c (rs6000_ra_ever_killed): Remove #ifdef
8474 ASM_OUTPUT_MI_THUNK and replace with check of targetm.
8475
8476 * doc/tm.texi (TARGET_ASM_OUTPUT_MI_THUNK): Update signature.
8477 (TARGET_ASM_OUTPU_MI_VCALL_THUNK): Likewise.
3aabf9a5 8478
433d5d04
BL
84792002-10-19 Brad Lucier <lucier@math.purdue.edu>
8480
8481 * real.c (do_add): Fix 0+0 sign corner case.
8482 (do_divide): Fix Inf/0 corner case.
8483
1194ca05
JH
8484Sun Oct 20 00:31:31 CEST 2002 Jan Hubicka <jh@suse.cz>
8485
8486 * i386.c (classify_argument): Pass MMX arguments in memory
8487 (ix86_expand_builtin): Expand proper address mode for cflush.
8488 * i386.md (movdqa): Fix typo.
8489 (sse2_cflush): Accept DImode addresses.
8490
8491 * xmmintrin.h (_mm_sqrt_sd): Accept two arguments.
8492 (_mm_max_sd): Fix pasto.
8493 (_mm_storeh_pd, _mm_storel_pd): Fix.
8494
8495 * i386.c (bdesc_comi): Fix to match specification.
8496 (ix86_expand_sse_comi): Emit the comparison properly.
8497 * i386.md (sse_comi, sse2_comi, sse_ucomi, sse2_ucomi):
8498 Do not use comparison operator.
8499 (vnmaskcmp): Fix template.
8500
8501 * xmmintrin.h (_mm_cvtps_pi16): Fix.
8502
3df5d99e
SP
85032002-10-19 Sebastian Pop <s.pop@laposte.net>
8504
8505 * dependence.c : Removed.
8bcefb43 8506 * Makefile.in : Remove dependence.o.
3df5d99e 8507
822eda12
JH
8508Sat Oct 19 10:46:52 CEST 2002 Jan Hubicka <jh@suse.cz>
8509
8510 * mmintrin.h (__m64): typedef it to v2si.
8511 (_mm_cvtsi32_si64, _mm_cvtsi32_si64_mm_sll_pi16,
8512 _mm_sll_pi32, _mm_sll_pi64, _mm_slli_pi64, _mm_sra_pi16,
8513 _mm_sra_pi32, _mm_srl_pi16, _mm_srl_pi32, _mm_srl_pi64,
8514 _mm_srli_pi64, _mm_and_si64, _mm_andnot_si64,
8515 _mm_or_si64, _mm_xor_si64): Add neccesary casts.
8516 * xmmintrin.h (_mm_setzero_si64): Likewise.
8517
8518 * i386.h (ALIGN_MODE_128): Update comment; add missing modes
8519 (SSE_REG_MODE_P, MMX_REG_MODE_P): New macros.
8520
8521 PR target/7693
8522 Patch by Shawn Wagner
8523 * mmintrin.h: Replace pi64 by si64.
8524
914a7297
DE
85252002-10-18 David Edelsohn <edelsohn@gnu.org>
8526
8527 * rs6000.md (movdf_hardfloat32): Order alternatives consistently.
8528 Use length of 4 not *.
8529 (movdf_hardfloat64): Same. Support DFmode moves to/from CTR/LR.
8530 (movdf_softfloat64): Likewise.
8531 (movdi_internal32): Use length of 4 not *.
8532 (movti_power): Same.
8533 (ctrsi, ctrdi): Same.
8534
4a7510cb
ZW
85352002-10-18 Zack Weinberg <zack@codesourcery.com>
8536
8537 * c-decl.c (start_decl): Point users of the old initialized-
8538 typedef extension at __typeof__.
8539
99c57613
RH
85402002-10-18 Richard Henderson <rth@redhat.com>
8541
8542 * real.c (cmp_significand_0, rtd_divmod, ten_to_mptwo): New.
8543 (real_to_decimal): Re-implement using the logic from the
8544 gcc 3.2 etoasc. Comment heavily.
8545 (div_significands): Simplify loop startup and comparison logic.
8546
483ab821
MM
85472002-10-18 Mark Mitchell <mark@codesourcery.com>
8548
8549 * target-def.h (TARGET_ASM_OUTPUT_MI_THUNK): Default to NULL.
8550 (TARGET_ASM_OUTPUT_MI_VCALL_THUNK): Likewise.
8551 (TARGET_ASM_OUT): Add them.
8552 * target.h (asm_out): Add output_mi_thunk and
8553 output_mi_vcall_thunk.
8554 * config/alpha/alpha.h (ASM_OUTPUT_MI_THUNK): Rename to ...
8555 (TARGET_ASM_OUTPUT_MI_THUNK): ... this.
8556 * config/arm/arm-protos.h (arm_output_mi_thunk): Declare.
8557 * config/arm/arm.c (arm_output_mi_thunk): Define.
8558 * config/arm/arm.h (ASM_OUTPUT_MI_THUNK): Rename to ...
8559 (TARGET_ASM_OUTPUT_MI_THUNK): ... this.
8560 * config/cris/cris.h (ASM_OUTPUT_MI_THUNK): Rename to ...
8561 (TARGET_ASM_OUTPUT_MI_THUNK): ... this.
8562 * config/frv/frv.h (ASM_OUTPUT_MI_THUNK): Rename to ...
8563 (TARGET_ASM_OUTPUT_MI_THUNK): ... this.
8564 * config/i386/i386-protos.h (x86_output_mi_thunk): Adjust
8565 prototype.
8566 (x86_output_mi_vcall_thunk): Declare.
8567 * config/i386/i386.c (override_options): Clear
8568 output_mi_vcall_thunk in 64-bit mode.
8569 (ix86_fntype_regparm): New function.
8570 (ix86_return_pops_args): Use it.
8571 (ia32_this_parameter): New function.
8572 (x86_output_mi_vcall_thunk): New function.
8573 (x86_output_mi_thunk): Use it
8574 * config/i386/unix.h (TARGET_ASM_OUTPUT_MI_THUNK): Adjust.
8575 (TARGET_ASM_OUTPUT_MI_VCALL_THUNK): Define.
8576 * config/i960/i960-protos.h (i960_output_mi_thunk): Declare.
8577 * config/i960/i960.c (i960_output_mi_thunk): New function.
8578 * config/i960/i960.h (ASM_OUTPUT_MI_THUNK): Adjust.
8579 * config/ia64/ia64-protos.h (ia64_output_mi_thunk): Declare.
8580 * config/ia64/ia64.c (ia64_output_mi_thunk): Define.
8581 * config/ia64/ia64.h (ASM_OUTPUT_MI_THUNK): Rename to ...
8582 (TARGET_ASM_OUTPUT_MI_THUNK): ... this.
8583 * config/m68k/m68k-protos.h (m68k_output_mi_thunk): New function.
8584 * config/m68k/linux.h (ASM_OUTPUT_MI_THUNK): Rename to ...
8585 (TARGET_ASM_OUTPUT_MI_THUNK): ... this.
8586 * config/m68k/netbsd-elf.h (ASM_OUTPUT_MI_THUNK): Rename to ...
8587 (TARGET_ASM_OUTPUT_MI_THUNK): ... this.
8588 * config/mmix/mmix.h (ASM_OUTPUT_MI_THUNK): Rename to ...
8589 (TARGET_ASM_OUTPUT_MI_THUNK): ... this.
8590 * config/pa/pa.h (ASM_OUTPUT_MI_THUNK): Rename to ...
8591 (TARGET_ASM_OUTPUT_MI_THUNK): ... this.
8592 * config/rs6000/sysv4.h (ASM_OUTPUT_MI_THUNK): Rename to ...
8593 (TARGET_ASM_OUTPUT_MI_THUNK): ... this.
8594 * config/s390/s390-protos.h (s390_output_mi_thunk): Declare.
8595 * config/s390/s390.c (s390_output_mi_thunk): Define.
8596 * config/s390/s390.h (ASM_OUTPUT_MI_THUNK): Rename to ...
8597 (TARGET_ASM_OUTPUT_MI_THUNK): ... this.
8598 * config/sparc/sparc.h (ASM_OUTPUT_MI_THUNK): Rename to ...
8599 (TARGET_ASM_OUTPUT_MI_THUNK): ... this.
8600 * config/stormy16/stormy16.h (ASM_OUTPUT_MI_THUNK): Rename to ...
8601 (TARGET_ASM_OUTPUT_MI_THUNK): ... this.
8602 * config/vax/vax-protos.h (vax_output_mi_thunk): Declare.
8603 * config/vax/vax.c (vax_output_mi_thunk): Define.
8604 * config/vax/vax.h (ASM_OUTPUT_MI_THUNK): Rename to ...
8605 (TARGET_ASM_OUTPUT_MI_THUNK): ... this.
8606 * doc/tm.texi: Adjust documentation.
4a7510cb 8607
90e021a0
JT
86082002-10-18 Jason Thorpe <thorpej@wasabisystems.com>
8609
4a7510cb
ZW
8610 * config/netbsd.h (NETBSD_ENABLE_EXECUTE_STACK): Define
8611 __enable_execute_stack function.
90e021a0
JT
8612 * config/alpha/netbsd.h (TRANSFER_FROM_TRAMPOLINE): Define
8613 as NETBSD_ENABLE_EXECUTE_STACK.
8614 * config/i386/netbsd-elf.h (TRANSFER_FROM_TRAMPOLINE): Ditto.
8615 * config/i386/netbsd.h (TRANSFER_FROM_TRAMPOLINE): Ditto.
8616 * config/i386/netbsd64.h (TRANSFER_FROM_TRAMPOLINE): Ditto.
8617 * config/sparc/netbsd-elf.h (TRANSFER_FROM_TRAMPOLINE): Ditto.
8618 * config/sparc/netbsd.h (TRANSFER_FROM_TRAMPOLINE): Ditto.
8619
5791cc29
JT
86202002-10-18 Jason Thorpe <thorpej@wasabisystems.com>
8621
8622 * config/i386/i386.c (x86_initialize_trampoline): Emit a call
8623 to __enable_execute_stack with the address of the trampoline
8624 if TRANSFER_FROM_TRAMPOLINE is defined.
8625 * config/i386/i386.h (TARGET_64BIT): Expand to a compile-time
8626 constant if building libgcc2.
8627
4977bab6
ZW
8628Thu Oct 17 17:40:05 CEST 2002 Jan Hubicka <jh@suse.cz>
8629
8630 * i386.c (pentium4_cost): Fix according to Intel recommendations.
8631 (ix86_memory_move_cost): Fix for 64bit compilation.
8632
7b35bba3
RS
86332002-10-17 Roger Sayle <roger@eyesopen.com>
8634
8635 * doc/c-tree.texi: Update description of COND_EXPR tree nodes.
8636
b991a865
GK
86372002-10-17 Geoffrey Keating <geoffk@apple.com>
8638
8639 * config/rs6000/rs6000.h (HARD_REGNO_MODE_OK): Allow arbitrary modes
8640 in CTR/LR/MQ.
8641 * config/rs6000/rs6000.md (movcc_internal1): Support CCmode moves
8642 to/from CTR/LR/MQ.
8643 (movsf_hardfloat): Support SFmode moves to/from CTR/LR/MQ.
8644 (movsf_softfloat): Likewise.
8645
fa870451
JJ
86462002-10-17 Janis Johnson <janis187@us.ibm.com>
8647
8648 * Makefile.in (site.exp): Add ALT_CXX_UNDER_TEST and COMPAT_OPTIONS.
8649
e31c2957
JT
86502002-10-17 Jason Thorpe <thorpej@wasabisystems.com>
8651
8652 * config/alpha/alpha.c (alpha_initialize_trampoline): Use
8653 tramp, not addr, to pass the trampoline address to
8654 __enable_execute_stack.
8655
48126a97
JH
8656Thu Oct 17 18:40:47 CEST 2002 Jan Hubicka <jh@suse.cz>
8657
8658 * mmintrin.h: Guard by __MMX__
8659 * xmmintrin.h: Guard by __SSE__
8660
8661 PR other/8062
8662 * xmmintrin.h (_MM_SHUFFLE2): New macro.
8663 (_mm_load*_?d): New functions.
8664 (_mm_set*_?d): New functions.
8665 (_mm_store*_?d): New functions.
8666
2ffa9932
JH
8667Wed Oct 16 15:01:29 CEST 2002 Jan Hubicka <jh@suse.cz>
8668
8669 Really commit patch announced at Oct 14
8670 PR c/7344
8671 * predict.c (can_predict_insn_p): New function.
8672 (estimate_probability): Avoid unnecesary work.
8673 (process_note_prediction): Likewise.
8674 * toplev.c (rest_of_compilation): Account early branch prediction pass
8675 as TV_BRANCH_PROB.
8676
ccc4bdea
JH
8677 PR other/8048
8678 Found by Ian Ollmann
8679 * xmmintrin.h (_mm_shuffle_pd): Fix typo.
8680 (_mm_load?_pd): Likewise.
8681 (_mm_store?_pd): Likewise.
8682
8683 PR target/7386
8684 * i386.c (builtin_description):Drop cmpg[te]s[sd].
8685 * xmmintrin.h (__mm_cmpg[te]_s[sd]): Rewrite using
8686 swapped alternative.
8687
8688 PR opt/7630
8689 * reload1.c (reload_inner_reg_of_subreg): New argument output;
8690 (push_reload): Update call.
8691
4db83639
RS
86922002-10-17 Richard Sandiford <rsandifo@redhat.com>
8693
8694 * config.gcc (mips*-*-*): Add OBJECT_FORMAT_ELF to $tm_defines
8695 if using mips/elf.h or mips/elf64.h.
8696 * config/mips/elf.h (OBJECT_FORMAT_ELF): Remove.
8697 * config/mips/elf64.h (OBJECT_FORMAT_ELF): Remove.
8698
f9dd72da
AH
86992002-10-16 Aldy Hernandez <aldyh@redhat.com>
8700
8701 * config/rs6000/rs6000.c (function_arg): Set inner mode of V1DI to
8702 SI.
8703
63a1ff86
UW
87042002-10-16 Ulrich Weigand <uweigand@de.ibm.com>
8705
8706 * config/s390/linux.h (ASM_DOUBLE, _ASM_OUTPUT_LONG): Remove.
8707 (LPREFIX): Likewise.
8708 (ASM_COMMENT_START, LOCAL_LABEL_PREFIX, ASM_FORMAT_PRIVATE_NAME,
8709 ASM_OUTPUT_ADDR_VEC_ELT, ASM_OUTPUT_ADDR_DIFF_ELT,
8710 ASM_OUTPUT_ALIGN, ASM_OUTPUT_SKIP, ASM_OUTPUT_ALIGNED_BSS,
8711 TEXT_SECTION_ASM_OP, DATA_SECTION_ASM_OP, BSS_SECTION_ASM_OP,
8712 GLOBAL_ASM_OP, ASM_OUTPUT_MI_THUNK): Move to s390.h.
8713
4a7510cb
ZW
8714 * config/s390/s390.h (ASM_COMMENT_START, LOCAL_LABEL_PREFIX,
8715 ASM_FORMAT_PRIVATE_NAME, ASM_OUTPUT_ALIGN, ASM_OUTPUT_SKIP,
8716 ASM_OUTPUT_ALIGNED_BSS, TEXT_SECTION_ASM_OP, DATA_SECTION_ASM_OP,
63a1ff86
UW
8717 BSS_SECTION_ASM_OP): Move from linux.h.
8718 (ASM_OUTPUT_ADDR_VEC_ELT, ASM_OUTPUT_ADDR_DIFF_ELT): Likewise.
8719 Also, use ASM_GENERATE_INTERNAL_LABEL instead of LPREFIX.
8720
4a7510cb 8721 * config/s390/s390.c (s390_function_profiler): Use
63a1ff86
UW
8722 ASM_GENERATE_INTERNAL_LABEL instead of LPREFIX.
8723
4977bab6
ZW
87242002-10-15 Eric Christopher <echristo@redhat.com>
8725
8726 * stor-layout.c (layout_type): Call GET_MODE_BITSIZE once.
8727 * java/parse.y (obtain_incomplete_type): Make pointer
8728 ptr_mode.
8729
da6eec72
RH
87302002-10-15 Richard Henderson <rth@redhat.com>
8731
8732 * real.c (real_to_decimal): Accept BUF_SIZE and CROP_TRAILING_ZEROS
8733 as arguments. Bound DIGITS by the available buffer size.
8734 (real_to_hexadecimal): Likewise.
8735 * real.h (real_to_decimal, real_to_hexadecimal): Update prototypes.
8736 (REAL_VALUE_TO_DECIMAL): Remove.
8737 * c-common.c, c-pretty-print.c, print-rtl.c, print-tree.c,
8738 sched-vis.c, config/arc/arc.c, config/c4x/c4x.c, config/fr30/fr30.c,
4a7510cb 8739 config/i370/i370.h, config/i386/i386.c, config/i960/i960.c,
da6eec72
RH
8740 config/ip2k/ip2k.c, config/m32r/m32r.c, config/m68hc11/m68hc11.c,
8741 config/m68k/hp320.h, config/m68k/m68k.h, config/m68k/sun2o4.h,
4a7510cb 8742 config/m68k/sun3.h, config/mips/mips.c, config/ns32k/ns32k.c,
da6eec72
RH
8743 config/pdp11/pdp11.h, config/vax/vax.h: Update all callers to
8744 use real_to_decimal directly, and with the proper arguments.
8745 * doc/tm.texi (REAL_VALUE_TO_DECIMAL): Remove.
8746
c15c18c5
JW
87472002-10-15 Jim Wilson <wilson@redhat.com>
8748
8749 * reload1.c (merge_assigned_reloads): After converting overlapping
8750 reloads to RELOAD_OTHER, abort if there are now conflicting reloads.
8751
8752 * config/i386/i386.md (adddi3_1): Add call to ix86_binary_operator_ok.
8753
74f6d071
JH
8754Tue Oct 15 22:08:35 CEST 2002 Jan Hubicka <jh@suse.cz>
8755
8756 * expr.c (do_tablejump): Fix typo in my previous commit.
8757
a2ee89d8
RS
87582002-10-15 Richard Sandiford <rsandifo@redhat.com>
8759
8760 * config/mips/vr.h (DRIVER_SELF_SPECS): Change %<mgp32 to %{<mgp32}.
8761
aee4e0db
UW
87622002-10-15 Ulrich Weigand <uweigand@de.ibm.com>
8763
8764 * config/s390/s390.c (s390_split_branches): Add return
8765 value. Add parameters TEMP_REG and TEMP_USED. Use unspec 104.
8766
8767 (find_base_register_in_addr): New function.
8768 (find_base_register_ref): New function.
8769 (replace_base_register_ref): New function.
8770
8771 (struct constant_pool): Add members pool_insn, insns, and anchor.
8772 Remove member last_insn.
8773 (s390_start_pool): Initialize them.
4a7510cb 8774 (s390_end_pool): Emit pool placeholder insn.
aee4e0db
UW
8775 (s390_add_pool_insn): New function.
8776 (s390_find_pool): Use insns bitmap instead of addresses.
8777 (s390_dump_pool): Replace placeholder insn. Emit anchor.
8778 Replace unspec 104 by local-pool-relative references.
8779 (s390_output_constant_pool): Output anchor label if required.
8780 (s390_output_symbolic_const): Handle unspec 104 and 105.
8781 (s390_add_pool): Remove, replace by ...
8782 (s390_add_constant, s390_find_constant): ... these new functions.
8783 (s390_add_anchor): New function.
8784
8785 (s390_chunkify_pool): Delete, replace by ...
4a7510cb 8786 (s390_chunkify_start, s390_chunkify_finish,
aee4e0db
UW
8787 s390_chunkify_cancel): ... these new functions.
8788 (s390_optimize_prolog): Add parameter TEMP_REGNO.
8789 Recompute register live data for special registers.
8790 (s390_fixup_clobbered_return_reg): New function.
8791 (s390_machine_dependent_reorg): Rewrite to use new
8792 s390_chunkify_... routines.
8793
8794 config/s390/s390.md ("reload_base"): Rename to ...
8795 ("reload_base_31"): ... this.
8796 ("reload_base_64"): New insn.
8797 ("reload_base2"): Remove.
8798 ("reload_anchor"): New insn.
8799 ("pool"): New insn.
8800
8801 s390.c (s390_pool_overflow): Remove.
8802 s390.h (s390_pool_overflow): Likewise.
8803 s390.md ("cjump", "icjump", "doloop_si"): Remove s390_pool_overflow.
8804
c034672a
R
8805Tue Oct 15 16:51:04 2002 J"orn Rennecke <joern.rennecke@superh.com>
8806
8807 * sh.md (movv8qi_i+2): Don't split if source is -1.
8808
b8db17af
JJ
88092002-10-15 Janis Johnson <janis187@us.ibm.com>
8810
8811 * doc/install.texi: Formatting changes for conformance to HTML 4.01.
8812
2d34c587
UW
88132002-10-15 Ulrich Weigand <uweigand@de.ibm.com>
8814
8815 PR opt/7409
8816 * loop.c (loop_regs_scan): Mark registers used for function
8817 argument passing as MAY_NOT_OPTIMIZE.
8818
4977bab6
ZW
8819Mon Oct 14 19:22:19 CEST 2002 Jan Hubicka <jh@suse.cz>
8820
8821 * gcov-io.h (gcov_info): Fix type.
8822 * profile.c (create_profiler): Fix type mismatch.
8823
1877be45
JH
8824Mon Oct 14 20:33:12 CEST 2002 Jan Hubicka <jh@suse.cz>
8825
8826 * i386.md (movv2di_internal): New pattern.
8827 (movv2df_internal, movv8hi_internal, movv16qi_internal): Fix predicate.
8828 (movv2di): New expander.
8829 * i386.c (ix86_preferred_reload_class): Return NO_REGS for vector operands.
8830
8831 * i386.c (ix86_expand_timode_binop_builtin): Delete.
8832 (builtin_description): Add SSE1 logicals; rename SSE2 logicals.
8833 (ix86_init_mmx_sse_builtins): Kill SSE1 logicals.
8834 (ix86_expand_builtin): Likewise.
8835 * i386.h (sse_andti4_df_1, sse_andti3_df_2, sse_andti3_sf_1, sse_andti3_sf_2,
4a7510cb 8836 sse_andti3,
1877be45 8837 sse_andnti4_df_1, sse_andti3_df_2, sse_andti3_sf_1, sse_andti3_sf_2,
4a7510cb 8838 sse_andnti3,
1877be45 8839 sse_orti4_df_1, sse_orti3_df_2, sse_orti3_sf_1, sse_orti3_sf_2,
4a7510cb 8840 sse_orti3,
1877be45 8841 sse_xorti4_df_1, sse_xorti3_df_2, sse_xorti3_sf_1, sse_xorti3_sf_2,
4a7510cb 8842 sse_xorti3): Kill.
1877be45
JH
8843 (sse_andv4sf3, sse_andnv4sf3, sse_orv2df3, sse_xorv2df3, sse_andv2df3,
8844 sse_andnv2df3, sse_orv2df3, sse_xorv2df3): New expanders.
8845 (*sse_andv4sf3, *sse_andnv2df3, *sse_orv4sf3, *sse_xorv4sf3, *sse_andv2df3,
8846 *sse_andnv2df3, *sse_orv2df3, *sse_xorv2df3): New patterns.
8847 (*sse_andsf3, *sse_andndf3, *sse_ordf3, *sse_xordf3, *sse_anddf3,
8848 *sse_andndf3, *sse_orv2df3, *sse_xorv2df3): New patterns.
8849
8850 * xmmintrin.h (__m128i): Define as __v2di.
8851
1877be45
JH
8852 PR c++/6419
8853 (expand_expr): Use DECL_RTL_SET_P.
8854
dbf4f1a2
RS
88552002-10-14 Roger Sayle <roger@eyesopen.com>
8856
8857 * combine.c (simplify_set): Treat MODE_CC registers like cc0.
8858
4f770e7b
RS
88592002-10-14 Roger Sayle <roger@eyesopen.com>
8860 Zack Weinberg <zack@codesourcery.com>
8861
8862 * config/i386/i386.c (k6_cost): Correct typo.
8863
a3b88570
MM
88642002-10-14 Mark Mitchell <mark@codesourcery.com>
8865
8866 PR optimization/6631
8867 * alias.c (objects_must_conflict_p): Check honor_readonly when
8868 examining TYPE_READONLY.
8869 * function.c (assign_stack_temp_for_type): Likewise.
8870
f5204e6c
FH
88712002-10-14 Falk Hueffner <falk.hueffner@student.uni-tuebingen.de>
8872
8873 * config/alpha/alpha.md (extendsidi2_nofix, extendsidi2_fix):
8874 Swap zero extension arguments.
8875 (umaxhi3): Fix instruction class.
8876 PR target/7211
8877 (prefetch): Fix prefetch instructions.
8878 PR target/7238
8879 (pkwb): Fix output constraint.
8880
40e6bc7e
AO
88812002-10-14 Alexandre Oliva <aoliva@redhat.com>
8882
8883 * config/mips/mips.c (print_operand): Increase buffer size for
8884 real numbers.
8885
f4e3e618
RH
88862002-10-14 Richard Henderson <rth@redhat.com>
8887
8888 PR opt/8165
8889 * gcse.c (adjust_libcall_notes): Revert last change.
8890 * simplify-rtx.c (simplify_replace_rtx): Handle LO_SUM.
8891
3eb429b2
AH
88922002-10-14 Andrew Haley <aph@redhat.com>
8893
8894 * tree-inline.c (remap_block): All local class initialization
8895 flags go in the outermost scope.
8896 (expand_call_inline): Call java_inlining_map_static_initializers.
8897 (expand_call_inline): Call java_inlining_merge_static_initializers.
8898 * java/lang.c (merge_init_test_initialization): New.
8899 (java_inlining_merge_static_initializers): New.
8900 (inline_init_test_initialization): New.
8901 (java_inlining_map_static_initializers): New.
8902
8903 * tree-inline.c (expand_call_inline): Convert retvar to expected
8904 type.
8905
34146b94
GS
89062002-10-14 Graham Stott <graham.stott@btinternet.com>
8907
8908 * stmt.c (decl_conflicts_with_clobbers_p): Add REG_P check.
8909
3a840c93
AH
89102002-10-14 Aldy Hernandez <aldyh@redhat.com>
8911
8912 * stmt.c: Fix typo in comment.
8913
7457a126
R
8914Mon Oct 14 11:35:49 2002 J"orn Rennecke <joern.rennecke@superh.com>
8915
8916 * c-common.c (c_common_type_for_mode): Add V2HImode case.
8917 * tree.c (build_common_tree_nodes_2): Initialize
8918 unsigned_V2HI_type_node and V2HI_type_node.
8919 * tree.h (enum tree_index): Add TI_UV2HI_TYPE and TI_V2HI_TYPE.
8920 (unsigned_V2HI_type_node, V2HI_type_node): Define.
8921
0d1c5774
JJ
89222002-10-14 Jakub Jelinek <jakub@redhat.com>
8923
8924 * config/i386/i386.h (ASM_OUTPUT_REG_PUSH, ASM_OUTPUT_REG_POP):
8925 Handle TARGET_64BIT.
8926
adadd183
RS
89272002-10-14 Richard Sandiford <rsandifo@redhat.com>
8928
8929 * config/mips/vr.h (DRIVER_SELF_SPECS): Define.
8930 * config/mips/t-vr (MULTILIB_OPTIONS): Remove mlong32.
8931 (MULTILIB_DIRNAMES): Remove long32.
8932 (MULTILIB_EXCEPTIONS): Don't build -mabi=32 -mgp32 multilibs.
8933 (MULTILIB_REDUNDANT_DIRS): Remove.
8934
db36994b
RS
89352002-10-14 Richard Sandiford <rsandifo@redhat.com>
8936
8937 * doc/tm.texi (DRIVER_SELF_SPECS): Document.
8938 * gcc.c (driver_self_specs): New variable.
8939 (do_self_spec): New function.
8940 (main): Use it to process driver_self_specs.
8941
11e5489b
RH
89422002-10-13 Richard Henderson <rth@redhat.com>
8943
4977bab6
ZW
8944 * config/i386/i386.c (ix86_function_ok_for_sibcall): Reject
8945 indirect sibcalls when regparm >= 3.
8946
8947 * config/i386/i386.c (sibcall_insn_operand): New.
8948 * config/i386/i386.h (PREDICATE_CODES): Update.
8949 * config/i386/i386-protos.h: Update.
8950 * config/i386/i386.md (sibcall_1, sibcall_value_1): Use it.
8951
11e5489b
RH
8952 * rtl.c (shallow_copy_rtx): Use memcpy for the entire node.
8953
4977bab6
ZW
89542002-10-12 Roger Sayle <roger@eyesopen.com>
8955
8956 * simplify-rtx.c (simplify_binary_operation) [ASHIFTRT]: Optimize
8957 arithmetic right shifts of ~0 during RTL simplifications.
8958
4ca1256f
NB
89592002-10-12 Neil Booth <neil@daikokuya.co.uk>
8960
8961 PR preprocessor/7862
8962 PR preprocessor/8190
8963 * gcc.c (cpp_unique_options): Don't delete .d files.
8964 Remove stray whitespace.
8965
cf860dc2
NS
89662002-10-12 Naohiko Shimizu <pshimizu@fa2.so-net.ne.jp>
8967
8968 * pdp11.h (ASM_OUTPUT_SKIP): Add preceding 0 for octal constant.
8969 (ASM_OUTPUT_COMMON, ASM_OUTPUT_LOCAL): Likewise.
8970 * pdp11.c (pdp11_output_function_prologue): 0%o -> %#o.
8971 (pdp11_output_function_epilogue, output_ascii): Likewise.
8972 (output_addr_const_pdp11): Likewise.
8973 * pdp11.md (movdi): Use offsetable memory for floating store.
8974 (lshrsi3, negsi2): Delete irrelevant comment.
8975
4977bab6
ZW
89762002-10-11 Andreas Bauer <baueran@in.tum.de>
8977
8978 * config/i386/i386.c (ix86_function_ok_for_sibcall): Allow
8979 indirect calls to be sibcall optimized.
8980 * config/i386/i386.md (sibcall_1): New.
8981 (call_1): Add no-sibcalls condition.
8982 (sibcall_value_1): New.
8983 (call_value_1): Add no-sibcalls condition.
8984
89852002-10-11 Eric Christopher <echristo@redhat.com>
8986
8987 * output.h (default_valid_pointer_mode): Declare.
8988 * varasm.c (default_valid_pointer_mode): Define.
8989 * target-def.h (TARGET_VALID_POINTER_MODE): Use.
8990 * target.h: Ditto.
8991 * tree.c (build_pointer_type_for_mode): New function.
8992 (build_pointer_type): Use.
8993 (build_reference_type_for_mode): New function.
8994 (build_reference_type): Use.
8995 * tree.h: Declare new functions.
8996 * c-common.c (handle_mode_attribute): Use new functions, check
8997 for type.
8998 * stor-layout.c (layout_type): Depend on machine mode for
8999 REFERENCE_TYPE and POINTER_TYPE.
9000 * dwarf2out.c (simple_type_size_in_bits): Move upward in file.
9001 (modified_type_die): Use instead of PTR_SIZE for POINTER_TYPE
9002 and REFERENCE_TYPE.
9003 * config/mips/mips.c (mips_valid_pointer_mode): New function.
9004 (TARGET_VALID_POINTER_MODE): Use and define.
9005 * config/mips/mips-protos.h (mips_valid_pointer_mode): Declare.
9006
5dd78e9a
GK
90072002-10-11 Geoffrey Keating <geoffk@apple.com>
9008
9009 * cse.c (mention_regs): Set SUBREG_TICKED to the register number,
9010 not the address of the REG.
9011 (struct cse_reg_info): Make subreg_ticked unsigned.
9012
8eb32f94
JJ
90132002-10-11 Janis Johnson <janis187@us.ibm.com>
9014
9015 * doc/compat.texi: Add info about C++ libraries.
9016
e197b6fc
RH
90172002-10-11 Richard Henderson <rth@redhat.com>
9018
9019 PR opt/8165
9020 * gcse.c (adjust_libcall_notes): Also adjust notes for INSN.
9021
a0bed689
JDA
90222002-10-11 John David Anglin <dave@hiauly1.hia.nrc.ca>
9023
9024 * cfganal.c (dfs_enumerate_from): Use PARAMS.
9025 * genautomata.c (output_insn_code_cases): Likewise.
9026 * real.c (real_format): Likewise.
9027 * tree.c (tree_size): Revise expressions using TREE_CODE_LENGTH to
9028 ensure value is promoted before doing subtraction.
9029
db655634
JH
9030Fri Oct 11 22:22:38 CEST 2002 Jan Hubicka <jh@suse.cz>
9031
9032 * calls.c (expand_call): Simplify noreturn call.
9033
9034 PR c/7344
9035 * cfgbuild.c (make_edges): Create edge cache when we do have
9036 large jumptable.
1877be45 9037 * expr.c (do_tablejump): Note size of maximal jumptable.
db655634
JH
9038 * function.c (prepare_function_start): Zero out size.
9039 * function.h (function): Add max_jumptable_ents.
9040
9041 * cfgcleanup.c (insn_match_p): Verify sibcall flag for calls to.
9042
750afc12
R
9043Fri Oct 11 12:34:33 2002 J"orn Rennecke <joern.rennecke@superh.com>
9044
9045 * sh.md (movv8qi_i+2): For V8QI destinations, generate V4HI
9046 register for mperm_w operation.
9047
0488fa7c
JR
9048Fri Oct 11 10:56:17 2002 J"orn Rennecke <joern.rennecke@superh.com>
9049
9050 * emit-rtl.c (gen_lowpart_common): When asked to make a vector from
9051 an integer, use simplify_gen_subreg.
9052
4977bab6
ZW
90532002-10-10 Diego Novillo <dnovillo@redhat.com>
9054
9055 * calls.c (flags_from_decl_or_type): Make extern.
9056 (ECF_*): Move ...
9057 * rtl.h (ECF_*): ... here.
9058 (flags_from_decl_or_type): Declare.
9059
90602002-10-10 Roger Sayle <roger@eyesopen.com>
9061 Nathan Sidwell <nathan@codesourcery.com>
9062
9063 * fold-const.c (fold) [RSHIFT_EXPR]: Optimize arithmetic right
9064 shifts of the form -1 >> x.
9065
9066Thu Oct 10 16:52:55 CEST 2002 Jan Hubicka <jh@suse.cz>
9067
9068 * cfgcleanup.c (insn_match_p): Verify sibcall flag for calls to.
9069
349e9f4b
AH
90702002-10-10 Aldy Hernandez <aldyh@redhat.com>
9071
9072 * extend.texi (Vector Extensions): Remove comment about single
9073 element vectors.
9074
7bdfd72e
KG
90752002-10-10 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
9076
9077 * fold-const.c (size_htab_hash): Use htab_hash_pointer.
9078 * function.c (insns_for_mem_hash): Likewise.
9079 * varasm.c (STRHASH): Likewise.
9080
46081bb3
SH
90812002-10-10 Stuart Hastings <stuart@apple.com>
9082
9083 * cse.c (struct cse_reg_info): Add subreg_ticked.
9084 (SUBREG_TICKED): New.
9085 (get_cse_reg_info): Initialize SUBREG_TICKED.
9086 (mention_regs): Use it.
9087 (invalidate): Set SUBREG_TICKED.
9088 (invalidate_for_call): Likewise.
9089 (addr_affects_sp_p): Likewise.
9090
9785f1d9
JJ
90912002-10-10 Jakub Jelinek <jakub@redhat.com>
9092
9093 * config/i386/i386.md (tls_local_dynamic_base): Put pic reg
9094 into proper operand.
9095
b6878188
DC
90962002-10-10 Denis Chertykov <denisc@overta.ru>
9097
9098 * config/ip2k/ip2k.c (function_epilogue): Optimize stack
9099 deallocation.
9100 * config/ip2k/libgcc.S: Combine routines used by function
9101 epilogue.
9102
f930bfd0
JW
91032002-10-10 Jim Wilson <wilson@redhat.com>
9104
9105 * cse.c (fold_rtx): Don't perform associative optimization for DIV and
9106 UDIV.
9107
5f5d5417
DE
91082002-10-10 David Edelsohn <edelsohn@gnu.org>
9109
9110 * config/rs6000/aix52.h: New file.
9111 * config/rs6000/t-aix52: New File.
9112 * config.gcc (rs6000-ibm-aix5.1.*): New entry.
9113 (rs6000-ibm-aix[56789].*): Default to AIX 5.2.
9114
7eafc329
JH
9115Thu Oct 10 19:37:54 CEST 2002 Jan Hubicka <jh@suse.cz>
9116
9117 PR target/5610
9118 * invoke.texi (-msse-math): Kill
9119 (-msse): Add note to mfpmath=sse.
9120
b105d6da
JH
9121Thu Oct 10 17:08:30 CEST 2002 Jan Hubicka <jh@suse.cz>
9122
9123 PR target/7723
9124 * i386.c (ix86_expand_vector_move): Do not generate const0->mem moves.
9125
5febdf0d
NB
91262002-10-10 Neil Booth <neil@daikokuya.co.uk>
9127
9128 PR preprocessor/8179
9129 * gcc.c (cpp_options): Add {ansi}, move %{m*} to same location
9130 as cc1_options.
9131 (default_compilers): Pass debug options when preprocessing
9132 stdin.
9133
7db40b5f
RH
91342002-10-06 Richard Henderson <rth@redhat.com>
9135
9136 * toplev.c (rest_of_compilation): Revert opt/2960 change.
9137
4977bab6
ZW
9138Wed Oct 9 21:18:43 CEST 2002 Jan Hubicka <jh@suse.cz>
9139
9140 * i386.c (*_cost): Add branch costs.
9141 (override_options): set ix86_branch_cost.
9142 (ix86_expand_int_movcc): Use BRANCH_COST.
9143 * i386.h (costs): Add branch_cost.
9144
95f79357
ZW
91452002-10-09 Zack Weinberg <zack@codesourcery.com>
9146
9147 PR c/7353
9148 * c-decl.c (start_decl): Unconditionally issue error for
9149 'typedef foo = bar'.
9150 (finish_decl): Remove special case for TYPE_DECL with initializer.
9151
9152 * doc/extend.texi: Delete "Naming Types" section. Change all
9153 cross-references to that section to refer to "Typeof" instead.
9154 Add the useful safe-max()-macro example from "Naming Types" to
9155 "Typeof", rewritten using that extension. Add some compatibility
9156 notes to "Typeof."
9157
44a5565d
KG
91582002-10-09 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
9159
9160 * loop.c: Revert 2002-08-15 change.
9161 (LOOP_REGNO_NREGS): Ensure type is int.
9162
a2419b96
DE
91632002-10-09 David Edelsohn <edelsohn@gnu.org>
9164
9165 * config/rs6000/rs6000.md (extenddftf2): Change to define_insn
9166 which copies first FPR and clears second.
9167 (extendsftf2): Same.
9168 (floatditf2): Fix typo.
9169 (floatsitf2): Same.
9170 (fix_trunctfdi2): Same.
9171 (fix_trunctfsi2): Same.
9172
fb7e6024
KG
91732002-10-09 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
9174
9175 * conflict.c (arc_hash): Change return type to hashval_t.
9176 * cselib.c (get_value_hash): Likewise.
9177 * genautomata.c (automaton_decl_hash, insn_decl_hash, decl_hash,
9178 state_hash, automata_list_hash): Likewise.
9179 * read-rtl.c (def_hash): Likewise.
9180 * tree.c (type_hash_hash): Likewise.
9181
36f7e964
AH
91822002-10-08 Aldy Hernandez <aldyh@redhat.com>
9183
9184 * config/rs6000/rs6000.c (rs6000_ra_ever_killed): Call
9185 prologue_epilogue_contains instead of using REG_MAYBE_DEAD notes.
9186
e3c62520
R
9187Wed Oct 9 15:54:49 2002 J"orn Rennecke <joern.rennecke@superh.com>
9188
9189 * sh.md (ffssi2): Fix emitted code.
9190
a3745024
UW
91912002-10-09 Ulrich Weigand <uweigand@de.ibm.com>
9192
9193 * cse.c (insn_live_p): Pass insn pattern, not full insn
9194 to may_trap_p.
9195
5cc67323
NB
91962002-10-09 Neil Booth <neil@daikokuya.co.uk>
9197
9198 * cppmacro.c (paste_tokens): Only allow / to paste with =.
9199
f5264b52
DE
92002002-10-09 David Edelsohn <edelsohn@gnu.org>
9201
9202 * config/rs6000/rs6000.md (movdf splitter): Use gen_int_mode on
9203 64-bit hosts.
9204 (movtf_internal): Reference correct displacement for second value
9205 in memory.
9206 (movtf splitter): Correct generation of constants in 64-bit mode.
9207
cef1c1ba
AM
92082002-10-09 Alan Modra <amodra@bigpond.net.au>
9209
9210 * libgcc2.c (__floatdisf): Properly cure double rounding.
9211
8d15eebc
GDR
92122002-10-09 Gabriel Dos Reis <gdr@integrable-solutions.net>
9213
9214 * c-common.c (cb_register_builtins): Define __WCHAR_MAX__.
9215 * doc/cpp.texi (Common Predefined Macros): Document.
9216
87ec8de9
GDR
92172002-10-09 Gabriel Dos Reis <gdr@integrable-solutions.net>
9218
9219 PR doc/7484
9220 * doc/invoke.texi (Option Summary): List
9221 -Wmissing-declarations as a C only option.
9222
4977bab6
ZW
92232002-10-08 Roger Sayle <roger@eyesopen.com>
9224
9225 * fold-const.c (fold) [LROTATE_EXPR, RROTATE_EXPR]: Optimize
9226 left and right rotates of ~0, i.e. integer_all_onesp (arg0).
9227 [LSHIFT_EXPR, RSHIFT_EXPR]: Optimize shifts and rotates of zero.
9228
9229Tue Oct 8 01:24:19 CEST 2002 Jan Hubicka <jh@suse.cz>
9230
9231 * i386.c (x86_sse_partial_reg_dependency, x86_sse_partial_regs,
9232 x86_sse_typeless_stores, x86_sse_load0_by_pxor): New global
9233 variables.
9234 (safe_vector_operand): Update sse_clrv4sf call.
9235 (ix86_expand_buildin): Likewise
9236 * i386.h (x86_sse_partial_reg_dependency, x86_sse_partial_regs,
9237 x86_sse_typeless_stores, x86_sse_load0_by_pxor): Declare.
9238 (TARGET_SSE_PARTIAL_REG_DEPENDENCY, TARGET_SSE_PARTIAL_REGS,
9239 TARGET_SSE_TYPELESS_STORES, TARGET_SSE_TYPELESS_LOAD0): New
9240 macros.
9241 * i386.md (movsf*, movdf*, movti, movv4sf, movv2df, movv16qi, movv8hi,
9242 movv4si): Obey the new flags.
9243 (floatsi2sf, floatdi2sf, truncatedf2sf): Emit extra load of 0 to avoid
9244 reformating penalty.
9245 (anddf, cmov patterns): Avoid reformating by first converting.
9246 (sse_cvtsd2ss): Fix predicate.
9247 (sse2_clrti): Fix mode,
9248 (sse_clrv4sf): Avoid unspec.
9249
fb7d9c35
JJ
92502002-10-08 Jakub Jelinek <jakub@redhat.com>
9251
9252 * config/sparc/t-linux64 (MULTILIB_OPTIONS): Remove
9253 mno-app-regs|mcmodel=medany.
9254 (MULTILIB_DIRNAMES, MULTILIB_OSDIRNAMES): Remove alt.
9255 (MULTILIB_EXCEPTIONS, MULTILIB_EXCLUSIONS, MULTILIB_MATCHES): Remove.
9256 (CRTSTUFF_T_CFLAGS): Define.
9257
11f3e4c7
RS
92582002-10-08 Roger Sayle <roger@eyesopen.com>
9259
9260 PR target/8087
9261 * simplify-rtx.c (avoid_constant_pool_reference): Allow constant
9262 pool references that are constructed using LO_SUM.
9263
bf52f899
NS
92642002-10-08 Nathan Sidwell <nathan@codesourcery.com>
9265
9266 * c-opts.c (c_common_decode_option): Add warn_strict_aliasing to
9267 -Wall.
9268 * c-typeck.c (build_c_cast): Use warn_strict_aliasing, tweak
9269 message.
9270 * flags.h (warn_strict_aliasing): Declare.
9271 * toplev.c (warn_strict_aliasing): Define.
9272 (lang_independent_options): Add it.
9273 * doc/invoke.texi (-Wstrict-aliasing): Document it.
9274
36624850
ZW
92752002-10-08 Zack Weinberg <zack@codesourcery.com>
9276
9277 * system.h (GCCBUGURL): Delete.
9278 * version.c (bug_report_url): New. Add commentary about
9279 modifying both these strings in modified distributions.
9280 * version.h: Declare bug_report_url.
9281
9282 * diagnostic.c, gcc.c, gcov.c: Globally replace GCCBUGURL with
9283 bug_report_url.
9284
218145d6
NC
92852002-10-08 Nick Clifton <nickc@redhat.com>
9286
9287 * config/rs6000/spe.h (__ev_set_acc_u64): Use __ev_create_u64 to
9288 convert uint64_t into __ev64_opaque__.
9289 (__ev_set_acc_s64): Likewise, but using signed types.
9290
bb02f6ed
UW
92912002-10-08 Ulrich Weigand <uweigand@de.ibm.com>
9292
9293 * config/s390/s390.md ("*doloop_si_long"): Add missing operand.
9294 ("*doloop_di_long"): Likewise.
9295
4fdbcfb2
JH
9296Tue Oct 8 16:50:10 CEST 2002 Jan Hubicka <jh@suse.cz>
9297
9298 * print-rtl.c (print_rtx): Increase buffer size for real numbers.
9299
e80f2609
RS
93002002-10-08 Richard Sandiford <rsandifo@redhat.com>
9301
9302 * config/mips/mips.md (define_attr cpu): Add r4111.
9303
36624850 93042002-10-08 Anthony Green <green@redhat.com>
4213a3b6 9305
36624850 9306 * bitmap.c (bitmap_equal_p): Clear all bitmap_head fields.
4213a3b6 9307
25009e02
MH
93082002-10-08 Michael Hayes <m.hayes@elec.canterbury.ac.nz>
9309
9310 * config/c4x/c4x.c (c4x_print_operand): Enlarge buffer
9311 for REAL_VALUE_TO_DECIMAL output.
9312
4977bab6
ZW
93132002-10-07 Richard Henderson <rth@redhat.com>
9314
9315 * cse.c (fixed_base_plus_p): Turn FIXED_BASE_PLUS_P into a
9316 function; cleanup PLUS case by using recursion. Update all users.
9317 (NONZERO_BASE_PLUS_P): Remove.
9318 (find_comparison_args): Use rtx_addr_can_trap_p instead.
9319 (fold_rtx): Use nonzero_address_p.
9320 * rtl.h (nonzero_address_p): Declare.
9321 * rtlanal.c (rtx_varies_p): Handle ADDRESSOF.
9322 (rtx_addr_can_trap_p): Likewise.
9323 (nonzero_address_p): New.
9324 * simplify-rtx.c (NONZERO_BASE_PLUS_P): Remove.
9325 (simplify_relational_operation): Use nonzero_address_p.
9326
fcce224d
DE
93272002-10-07 David Edelsohn <edelsohn@gnu.org>
9328
9329 * config/rs6000/rs6000.c (rs6000_override_options): Set
9330 real_format_for_mode for IBM extended format, if enabled.
9331 (easy_fp_constant): Add TFmode.
9332 (rs6000_legitimize_address): Add TFmode.
9333 (rs6000_legitimate_address): Same.
9334 (function_arg_advance): TFmode uses two FPRs.
9335 (rs6000_emit_prologue): Fix warning.
9336 (rs6000_output_function_epilogue): Add TFmode.
9337 (output_toc): Add TFmode.
9338 * rs6000.h (SLOW_UNALIGNED_ACCESS): Add TFmode.
9339 (LEGITIMATE_OFFSET_ADDRESS_P): Add TFmode.
9340 * rs6000.md (movtf splitter): Load TFmode constant.
9341
dad482e6 93422002-10-07 Dale Johannesen <dalej@apple.com>
fcce224d 9343
dad482e6
DJ
9344 * rtl.h: Add NOTE_PRECONDITIONED.
9345 * unroll.c: Set it.
9346 * loop.c: Set loop_info->preconditioned from it.
9347 * doloop.c: Permit doloop treatment when loop_info->preconditoned.
9348
de3beb7c
RH
93492002-10-07 Richard Henderson <rth@redhat.com>
9350
9351 * config/i960/i960.c (i960_setup_incoming_varargs): Create a
9352 new rtx for comparing the argument pointer against zero.
9353 (i960_va_start): Similarly.
9354
87cb2a87
RH
93552002-10-07 Richard Henderson <rth@redhat.com>
9356
9357 * config/i960/i960.md (*): Use TFmode, not XFmode.
9358 * config/i960/i960.c (*): Likewise.
9359 (i960_arg_size_and_align): Remove XFmode alignment hack.
9360 (i960_round_align): Merge code from ROUND_TYPE_ALIGN.
9361 * config/i960/i960.h (LONG_DOUBLE_TYPE_SIZE): Use 128, not 96.
9362 (MAX_LONG_DOUBLE_TYPE_SIZE): Likewise.
9363 (DATA_ALIGNMENT, ROUND_TYPE_SIZE): Remove.
9364
5ef38d2a
RH
93652002-10-07 Richard Henderson <rth@redhat.com>
9366
9367 * config/fp-bit.c (EXTENDED_FLOAT_STUBS): Flush out all XF/TFmode
9368 entry points; use void return value and argument list.
9369
4977bab6
ZW
93702002-10-06 Andreas Bauer <baueran@in.tum.de>
9371
9372 * calls.c (expand_call): Fix function-is-volatile check.
9373
e7f9979a
NS
93742002-10-05 Naohiko Shimizu <nshimizu@keyaki.cc.u-tokai.ac.jp>
9375
9376 * t-pdp11: Add MULTILIB support for msoft-float.
9377 * pdp11.h (LEGITIMATE_CONSTANT_P): Fix soft-float case.
9378
9379 * t-pdp11: Add LIB2FUNCS_EXTRA.
36624850 9380 * pdp11.c (pdp11_output_function_prologue): Restrict offset to 16bit,
e7f9979a
NS
9381 add preceding 0 to the octal constant, rename 'fp' to 'r5', rename
9382 'fldd' to 'ldd', rename 'fstd' to 'std'.
9383 (pdp11_output_function_epilogue): Likewise.
9384 (output_move_quad): Make the comment gas compatible.
9385 (output_ascii): Add preceding 0 to the octal constant.
9386 (print_operand_address): Add pre_modify, post_modify.
9387 (output_addr_const_pdp11): Add preceding 0 to the octal constant.
9388 * pdp11.h (GO_IF_LEGITIMATE_ADDRESS) : Add 'movb' pre_modify case
36624850 9389 with the indication of Paul Koning.
e7f9979a
NS
9390 (PRINT_OPERAND): Fix floating constant.
9391 * pdp11.md (movdi): Restrict matching pattern.
9392 (movqi): Generalize the matching pattern.
9393 (movdf): Restrict matching pattern.
9394 (zero_extendqihi2): Change constant representation.
9395 (floatsidf2): Fix wrong operands.
9396 (addqi3): Fix wrong instruction name.
9397 (subqi3): Fix wrong instruction name.
9398 (andsi3, andhi3, andqi3): Simplify and fix to use 'bic'.
9399 (xorsi3): Fix wrong insn.
9400 (one_cmplqi2): Add two operand pattern.
9401 (lsrsi3): New.
9402 (negsi2): New.
9403 (call): Add register indirect case.
9404 (mod): Fix wrong subreg.
9405
a9b6f1e7 94062002-10-06 Eric Botcazou <ebotcazou@libertysurf.fr>
36624850 9407 Volker Reichelt <reichelt@igpm.rwth-aachen.de>
4ef7870a
EB
9408
9409 PR c/7411
9410 * expr.c (expand_expr) [PLUS]: Simplify after the operands
9411 have been expanded in EXPAND_NORMAL mode.
9412
a2900460
RH
94132002-10-06 Richard Henderson <rth@redhat.com>
9414
9415 * config/rs6000/rs6000.md (load_toc_v4_PIC_2): Fix base constraint.
9416
ff025ab9
RH
94172002-10-06 Richard Henderson <rth@redhat.com>
9418
9419 PR optimization/2960
9420 * toplev.c (rest_of_compilation): Don't copy_loop_headers if
9421 optimize_size.
9422
48b80d93
AO
94232002-10-06 Alexandre Oliva <aoliva@redhat.com>
9424
9425 * config/mips/mips.h (SIZE_TYPE, PTRDIFF_TYPE): Override
9426 previously definitions.
9427
7c7c549e
FCE
94282002-10-06 Frank Ch. Eigler <fche@redhat.com>
9429
9430 * cppinit.c (init_standard_includes, parse_option): Use strncmp.
9431 * c-opts.c (find_opt): Similarly.
9432
4977bab6
ZW
9433Sat Oct 5 22:48:06 CEST 2002 Jan Hubicka <jh@suse.cz>
9434
9435 * athlon.md: rewrite to DFA.
9436 * i386 (ix86_adjust_cost): Drop memory latency code.
9437 (ia32_use_dfa_pipeline_interface): Return true for Athlon.
9438
c49d2df6
JJ
94392002-10-05 Jakub Jelinek <jakub@redhat.com>
9440
9441 * gcc.c (set_multilib_dir): Don't access *end.
9442 Use memcpy instead of strncpy. Don't write beyond malloced buffer.
9443 (print_multilib_info): Don't show paths starting with ".:".
9444 * genmultilib: Add new option, "yes" if multilibs are enabled.
9445 Update comments. If multilibs not enabled, print .:${osdirout}
9446 for each directory. If multilibs are enabled, always print
9447 ${dirout}:${osdirout}, even if the two are the same.
9448 * Makefile.in (s-mlib): Pass @enable_multilib@ to genmultilib.
9449 Pass all MULTILIB_* variables to genmultilib even if
9450 --disable-multilib but MULTILIB_OSDIRNAMES is not empty.
9451
4977bab6
ZW
94522002-10-04 Zack Weinberg <zack@codesourcery.com>
9453
9454 * gcc.c (process_command): Set .validated for -pipe. Correct
9455 grammar in comment.
9456
d758c1db
BK
94572002-10-04 Bruce Korb <bkorb@gnu.org>
9458
9459 * fixinc/inclhack.def(hpux11_abs): use format fix
9460 * fixinc/fixincl.x: regenerate
9461 * fixinc/tests/base/stdlib.h: accommodate new fix test
9462
b3dc87c5
JH
9463Sat Oct 5 19:42:45 CEST 2002 Jan Hubicka <jh@suse.cz>
9464
9465 * c-common.c (cb_register_builtins): Use really_no_inline.
9466
f7a21c70
DE
94672002-10-04 David Edelsohn <edelsohn@gnu.org>
9468
9469 * unroll.c (copy_loop_body): Remove REG_EQUAL note attached to
9470 copied instruction if the note is not loop invariant.
9471
081d6fb9
LR
94722002-10-04 Loren J. Rittle <ljrittle@acm.org>
9473
9474 * gcc/ginclude/stddef.h: Support the FreeBSD 5 typedef system.
9475
c5d3d49b
SE
94762002-10-04 Steve Ellcey <sje@cup.hp.com>
9477
9478 * doc/invoke.texi (HPPA): Add -mlinker-opt, -mgnu-ld,
9479 and -mhp-ld options to list of options. Add -mgnu-ld
9480 and -mhp-ld option descriptions.
9481
0fca111b
SE
94822002-10-04 Steve Ellcey <sje@cup.hp.com>
9483
9484 * fixinc/inclhack.def (hpux11_abs): New.
9485 (stdio_va_list): change __va_list__ to __gnuc_va_list.
9486 * fixinc/fixincl.x: Rebuild.
9487
229b303a
RS
94882002-10-04 Roger Sayle <roger@eyesopen.com>
9489
9490 * config/i386/i386.h (processor_costs): Add new fields fadd,
9491 fmul, fdiv, fabs, fchs and fsqrt to costs structure.
9492 (RTX_COSTS): Use these fields to determine the RTX costs
9493 of floating point addition/subtraction, multiplication,
9494 division, fabs, negation and square root respectively.
9495 * config/i386/i386.c (size_cost): Provide instruction sizes
9496 for these new fields.
9497 (i386_cost, i486_cost, pentium_cost, pentiumpro_cost,
9498 k6_cost, athlon_cost, pentium4_cost): Provide typical cycle
9499 counts for these new fields for all x86 processor variants.
9500
481ed21a
KG
95012002-10-04 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
9502
6017ba03
KG
9503 * mips.c (mips_const_double_ok): Delete unused variable.
9504
481ed21a
KG
9505 * gengtype.c (rtx_next): Change type to int.
9506
635f4680
AJ
95072002-10-04 Andreas Jaeger <aj@suse.de>
9508
9509 * config/i386/t-linux64 (MULTILIB_OSDIRNAMES): Fix value.
9510
ee6ff319
RH
95112002-10-04 Richard Henderson <rth@redhat.com>
9512
9513 * real.h (SIGNIFICAND_BITS): Add one more word.
9514 (CONST_DOUBLE_FORMAT): Accomodate 6 words.
9515 * real.c (times_pten): New.
9516 (real_to_decimal, real_from_string): Use it.
9517 (sticky_rshift_significand): Use & to find modulus.
9518 (rshift_significand, lshift_significand): Likewise.
9519 (do_divide): Apply sticky bit after normalization.
9520 (real_to_decimal, real_to_hexadecimal): Fix sign of Inf and NaN.
9521
4977bab6
ZW
95222002-10-03 Andreas Bauer <baueran@in.tum.de>
9523
9524 * doc/tm.texi (FUNCTION_OK_FOR_SIBCALL): Remove.
9525 (TARGET_FUNCTION_OK_FOR_SIBCALL): New.
9526
6d8dd940
AJ
95272002-10-03 Andreas Jaeger <aj@suse.de>
9528
9529 * gengtype.c (adjust_field_rtx_def): Cast variables of type size_t
9530 to unsigned long, adjust printf format string.
9531 (output_mangled_typename): Likewise.
9532
191fe2bb
JT
95332002-10-03 Jason Thorpe <thorpej@wasabisystems.com>
9534
9535 * config/vax/vax.c (vax_output_function_prologue): Use asm_fprintf.
9536 * config/vax/vax.h (VAX_FUNCTION_PROFILER_NAME): New.
9537 (FUNCTION_PROFILER): Rewrite to use ASM_GENERATE_INTERNAL_LABEL,
9538 assemble_name, asm_fprintf, and VAX_FUNCTION_PROFILER_NAME.
9539 (ASM_OUTPUT_MI_THUNK): Use asm_fprintf instead of REGISTER_PREFIX.
9540 (PRINT_OPERAND_PUNCT_VALID_P): Fix comment.
9541 * config/vax/elf.h (FUNCTION_PROFILER): Remove.
9542 (VAX_FUNCTION_PROFILER_NAME): Redefine as "__mcount".
9543
6397d80b
MM
95442002-10-03 Mark Mitchell <mark@codesourcery.com>
9545
9546 * doc/invoke.texi (-Wabi): Document mangling bug.
9547
69c75916
AM
95482002-10-04 Alan Modra <amodra@bigpond.net.au>
9549
9550 * config/rs6000/rs6000.c (rs6000_output_function_epilogue): Use a
9551 name for the tbtab label that depends on the function asm name.
9552 Don't output tbtab label unless optional_tbtab.
9553 (output_mi_thunk): Formatting.
9554
adf2ac37
RH
95552002-10-03 Richard Henderson <rth@redhat.com>
9556
9557 * config/m68k/m68k.h (OVERRIDE_OPTIONS): Move additional code ...
9558 * config/m68k/m68k.c (override_options): ... here.
9559 * config/m68k/m68kelf.h (OVERRIDE_OPTIONS): Remove.
9560 * config/m68k/m68kv4.h (OVERRIDE_OPTIONS): Remove.
9561 * config/m68k/linux.h (SUBTARGET_OVERRIDE_OPTIONS): Remove.
9562 * config/m68k/netbsd-elf.h (SUBTARGET_OVERRIDE_OPTIONS): Remove.
9563
a7519393
RH
95642002-10-03 Richard Henderson <rth@redhat.com>
9565
9566 * real.h (struct real_value): Use ENUM_BITFIELD.
9567
41552736
RH
95682002-10-03 Richard Henderson <rth@redhat.com>
9569
9570 * config/i960/i960.md (call, call_value): Use emit_call_insn.
9571
882affa8
SE
95722002-10-03 Steve Ellcey <sje@cup.hp.com>
9573
9574 * config/pa/pa64-hpux.h (INIT_ENVIRONMENT): New.
9575
83eb95f9
SE
95762002-10-03 Steve Ellcey <sje@cup.hp.com>
9577
9578 * config.gcc (hppa*64*-*-hpux11*): Check gnu_ld.
9579 * config/pa/pa.h (MASK_GNU_LD): New.
9580 (TARGET_GNU_LD): New.
6d8dd940 9581 * config/pa/pa64-hpux.h (LINK_SPEC): Set based
83eb95f9
SE
9582 on gnu-ld and MASK_GNU_LD.
9583 (SUBTARGET_SWITCHES): New gnu-ld & hp-ld flags.
9584
b72b1c29
JH
9585Thu Oct 3 23:35:51 CEST 2002 Jan Hubicka <jh@suse.cz>
9586
9587 * i386.c (athlon_cost): Fix the move costs.
9588
92b7a2a5
JH
9589Thu Oct 3 23:20:58 CEST 2002 Jan Hubicka <jh@suse.cz>
9590
9591 * final.c (final): Use symbol name as function name for profiling.
9592 * profile.c (get_exec_counts): Likewise.
9593 (branch_prob): Likewise.
9594
429489e5
JJ
95952002-10-03 Jakub Jelinek <jakub@redhat.com>
9596
9597 * longlong.h (__udiv_qrnnd): Remove PARAMS from prototype.
9598
5bbcd587
JJ
95992002-10-03 Jakub Jelinek <jakub@redhat.com>
9600
9601 * gcc.c (print_multi_os_directory): New variable.
9602 (option_map): Support --print-multi-os-directory.
9603 (struct prefix_list): Add os_multilib field.
9604 (multilib_os_dir): New variable.
9605 (static_specs): Add multilib_options.
9606 (find_a_file): Add multilib argument. Search in GCC or OS multilib
272d0bee 9607 subdirs if nonzero.
5bbcd587
JJ
9608 (read_specs, execute): Update callers.
9609 (find_file): Likewise. Don't prefix name with multilib_dir, instead
9610 pass 1 as multilib option.
9611 (display_help): Include --print-multi-os-directory.
9612 (add_prefix): Add os_multilib argument. Initialize pl->os_multilib.
9613 (process_command): Update callers. Handle --print-multi-os-directory.
9614 (do_spec_1) ['D']: Use multilib_os_directory if pl->os_multilib is
9615 set.
9616 (main): Update find_a_file and add_prefix callers.
9617 Handle print_multi_os_directory.
9618 (struct mdswitchstr): New.
9619 (mdswitches, n_mdswitches): New variables.
9620 (used_arg): Add MULTILIB_DEFAULT switches too if they are not
9621 present on the command line nor their mutually incompatible
9622 switches.
9623 (default_arg): Optimize.
9624 (set_multilib_dir): Compute multilib_os_dir. Initialize mdswitches
9625 array.
9626 (print_multilib_info): Only print GCC multilib dir name, not OS
9627 multilib dirname.
9628 * genmultilib: Add osdirnames parameter. Output multilib_options
9629 variable. If osdirnames is specified, output dirnames as
9630 dirname:osdirname.
9631 * mklibgcc.in: Use MULTILIB_OSDIRNAMES, --print-multi-directory
9632 and --print-multi-os-directory instead of SHLIB_SLIBDIR_SUFFIXES
9633 to compute libgcc_s soname and install path.
9634 * Makefile.in (libgcc.mk): Pass MULTILIB_OSDIRNAMES instead of
9635 SHLIB_SLIBDIR_SUFFIXES to mklibgcc.
9636 (s_mlib): Pass MULTILIB_OSDIRNAMES or nothing as last genmultilib
9637 argument.
9638
9639 * config/sparc/t-linux64 (MULTILIB_OSDIRNAMES): Set.
9640 (SHLIB_SLIBDIR_SUFFIXES): Remove.
9641 * config/sparc/linux64.h (STARTFILE_SPEC32, STARTFILE_SPEC64,
9642 ENDFILE_SPEC32, ENDFILE_SPEC64, ENDFILE_COMMON): Remove.
9643 (STARTFILE_SPEC, ENDFILE_SPEC): Don't distinguish between -m32
9644 and -m64.
9645 * config/sparc/t-sol2-64 (MULTILIB_OSDIRNAMES): Set.
9646 (SHLIB_SLIBDIR_SUFFIXES): Remove.
9647 * config/sparc/sol2-bi.h (STARTFILE_ARCH64_SPEC): Remove.
9648 (STARTFILE_ARCH_SPEC): Remove.
9649 * config/i386/t-linux64 (MULTILIB_OSDIRNAMES): Set.
9650 (SHLIB_SLIBDIR_SUFFIXES): Remove.
9651 * config/i386/linux64.h (STARTFILE_PREFIX_SPEC): Remove.
9652 * config/mips/t-iris6 (MULTILIB_OSDIRNAMES): Set.
9653 (SHLIB_SLIBDIR_SUFFIXES): Remove.
9654
c07f146f
JH
9655Thu Oct 3 21:42:20 CEST 2002 Jan Hubicka <jh@suse.cz>
9656
9657 * predict.c (choose_function_section): Avoid choice for linkonce functions.
9658
4c9c9a3d
JH
9659Thu Oct 3 15:15:00 CEST 2002 Jan Hubicka <jh@suse.cz>
9660
9661 * i386.md (lea to mul peep2): Fix condition.
6d8dd940 9662
f50df1d5
JDA
96632002-10-02 John David Anglin <dave@hiauly1.hia.nrc.ca>
9664
9665 * pa-linux.h (FUNCTION_OK_FOR_SIBCALL): Delete macro.
9666 * pa32-linux.h (FUNCTION_OK_FOR_SIBCALL): Define.
9667
4977bab6
ZW
96682002-10-02 David Mosberger-Tang <David.Mosberger@acm.org>
9669
9670 * unwind.h (_Unwind_GetTextRelBase): Mark _C argument with
9671 attribute "unused".
9672
9673 * config/t-libunwind: Mention unwind-sjlj.c.
9674 * unwind-libunwind.c: Change #ifdef __USING_LIBUNWIND_EXCEPTIONS__
9675 to #ifndef __USING_SJLJ_EXCEPTIONS__.
9676
9677 * configure.in: Move sjlj-exceptions and --enable-libunwind-exceptions
9678 before inclusion of config.gcc, but after configuring the compiler etc.
9679 Determine default value for --enable-libunwind-exceptions based on
9680 whether the host has a libunwind library (not guaranteed to be correct,
9681 but it's a reasonable first guess and can always be overridden with an
9682 explicit --enable/disable-libunwind-exceptions.
9683 * config.gcc: For target ia64*-*-linux*, mention t-libunwind as a
9684 tmake_file when $use_libunwind_exceptions is enabled.
9685 * Makefile.in: Update comment: LIB2ADDEH is updated not just by
9686 ia64 (e.g., config/t-linux also updates it).
9687 * gcc.c (init_spec) [USE_LIBUNWIND_EXCEPTIONS]: Mention -lunwind
9688 along with the shared version of libgcc since the latter requires
9689 the former.
9690 * unwind-libunwind.c: New file.
9691 * config/t-libunwind: Ditto.
9692
96932002-10-02 Nathanael Nerode <neroden@gcc.gnu.org>
9694
9695 * config.gcc: Remove support for vax-*-vms*.
9696 * config/vax/vms.h: Remove.
9697 * config/vax/xm-vms.h: Remove.
9698 * config/vax/vax-protos.h: Remove VMS-specific code.
9699 * config/vax/vax.c: Remove VMS-specific code.
9700
d631b80a
RH
97012002-10-02 Richard Henderson <rth@redhat.com>
9702
9703 PR opt/7124
9704 * config/i386/i386.c (ix86_register_move_cost): Increase cost
9705 for secondary_memory_needed pairs.
9706
854ef390
NN
97072002-10-02 Nathanael Nerode <neroden@gcc.gnu.org>
9708
9709 * doc/vms.texi: Blow away false include file section.
9710
f963b5d9
RS
97112002-10-02 Roger Sayle <roger@eyesopen.com>
9712
9713 PR optimization/6627
9714 * toplev.c (force_align_functions_log): New global variable.
9715 * flags.h (force_align_functions_log): Add extern prototype.
9716 * varasm.c (assemble_start_function): Use it to force minimum
9717 function alignment.
9718 * config/i386/i386.h (FUNCTION_BOUNDARY): Set the correct
9719 minimum function alignment to one byte.
9720 (TARGET_PTRMEMFUNC_VBIT_LOCATION): Store the virtual bit in
9721 the least significant bit of vtable member function pointers.
9722 * tree.h (enum ptrmemfunc_vbit_where_t): Move definition to
9723 here from cp/cp-tree.h.
9724
200bcf7e
JH
9725Wed Oct 2 17:01:36 CEST 2002 Jan Hubicka <jh@suse.cz>
9726
9727 * i386.c (print_operand_address): Use RIP addressing for offsetted
9728 label refs too.
9729
88d0be17
DM
97302002-09-30 David S. Miller <davem@redhat.com>
9731
9732 PR middle-end/7151
9733 * config/sparc/sparc.md (movdi_insn_sp32_v9): Accept 'e' regs.
9734 (movdi reg/reg split): Match only on sparc32, and v9 when int regs.
9735
4977bab6
ZW
97362002-10-01 Andreas Bauer <baueran@in.tum.de>
9737
9738 * calls.c (expand_call): Remove the `no indirect check'
9739 for sibcall optimization; use function_ok_for_sibcall
9740 target hook; refine check for `function is volatile'.
9741 (FUNCTION_OK_FOR_SIBCALL): Remove the redefinition.
9742 * hooks.c (hook_tree_tree_bool_false): New.
9743 * hooks.h (hook_tree_tree_bool_false): Declare.
9744 * target-def.h (TARGET_FUNCTION_OK_FOR_SIBCALL): New.
9745 (TARGET_INITIALIZER): Add it.
9746 * target.h (struct gcc_target): Add function_ok_for_sibcall.
9747 * config/alpha/alpha.c: (alpha_function_ok_for_sibcall): New.
9748 (TARGET_FUNCTION_OK_FOR_SIBCALL): Redefine accordingly.
9749 * config/alpha/alpha.h: (FUNCTION_OK_FOR_SIBCALL): Remove.
9750 * config/arm/arm-protos.h: (arm_function_ok_for_sibcall):
9751 Remove function declaration.
9752 * config/arm/arm.c: (arm_function_ok_for_sibcall): Make
9753 function static and accept another argument of type `tree'.
9754 (TARGET_FUNCTION_OK_FOR_SIBCALL): Redefine accordingly.
9755 * config/arm/arm.h: (FUNCTION_OK_FOR_SIBCALL): Remove.
9756 * config/frv/frv.h: (FUNCTION_OK_FOR_SIBCALL): Remove.
9757 * config/i386/i386.c: (ix86_function_ok_for_sibcall): New.
9758 (TARGET_FUNCTION_OK_FOR_SIBCALL): Redefine accordingly.
9759 * config/i386/i386.h: (FUNCTION_OK_FOR_SIBCALL): Remove.
9760 * config/pa/pa-linux.h: (FUNCTION_OK_FOR_SIBCALL): Remove.
9761 (TARGET_HAS_STUBS_AND_ELF_SECTIONS): New definition.
9762 * config/pa/pa.c: (pa_function_ok_for_sibcall): New.
9763 (TARGET_FUNCTION_OK_FOR_SIBCALL): Redefine accordingly.
9764 * config/pa/pa.h: (FUNCTION_OK_FOR_SIBCALL): Remove.
9765 * config/rs6000/rs6000-protos.h: (function_ok_for_sibcall):
9766 Remove function declaration.
9767 * config/rs6000/rs6000.c: (rs6000_function_ok_for_sibcall):
9768 Rename function_ok_for_sibcall to rs6000_function_ok_for_sibcall;
9769 rename first argument to `decl'; accept another argument
9770 of type `tree'; make static.
9771 (TARGET_FUNCTION_OK_FOR_SIBCALL): Redefine accordingly.
9772 * config/rs6000/rs6000.h: (FUNCTION_OK_FOR_SIBCALL): Remove.
9773 * config/sh/sh.c: (sh_function_ok_for_sibcall): New.
9774 (TARGET_FUNCTION_OK_FOR_SIBCALL): Redefine accordingly.
9775 * config/sh/sh.h: (FUNCTION_OK_FOR_SIBCALL): Remove.
9776 * config/sparc/sparc.c: (sparc_function_ok_for_sibcall): New.
9777 (TARGET_FUNCTION_OK_FOR_SIBCALL): Redefine accordingly.
9778 * config/sparc/sparc.h: (FUNCTION_OK_FOR_SIBCALL): Remove.
9779 * config/xtensa/xtensa.h: (FUNCTION_OK_FOR_SIBCALL): Remove.
9780
f10aac29
RS
97812002-10-01 Roger Sayle <roger@eyesopen.com>
9782
9783 * unroll.c (loop_iterations): Revert 2002-09-08 change.
9784
69bd00e6
RH
97852002-10-01 Richard Henderson <rth@redhat.com>
9786
9787 * real.c (real_to_decimal): Crop trailing zeros for DIGITS < 0.
9788 (real_to_hexadecimal): Likewise.
9789 * print-rtl.c (print_rtx): If we are linked with real.c, don't
9790 dump the XWINT fields of a floating point CONST_DOUBLE.
9791
3b5742ab
JT
97922002-10-01 Jason Thorpe <thorpej@wasabisystems.com>
9793
9794 * config/vax/elf.h (FUNCTION_PROFILER): Fix __mcount call.
9795
fd1e5d25
RH
97962002-10-01 Richard Henderson <rth@redhat.com>
9797
9798 * calls.c (precompute_register_parameters): Force non-legitimate
9799 constants into pseudos.
9800
78872ad9
NC
98012002-10-01 Nick Clifton <nickc@redhat.com>
9802
9803 * config/rs6000/spe.md (spe_evrlwi): Add missing third operand
9804 to assembler template.
9805
3c655f42
RH
98062002-10-01 Richard Henderson <rth@redhat.com>
9807
9808 * dwarf2out.c (loc_descriptor_from_tree): Relax requirement
9809 for TLS debug info to !DECL_EXTERNAL.
9810
ec20cffb 98112002-10-01 Matt Thomas <matt@3am-software.com>
ee6ff319 9812 Jason Thorpe <thorpej@wasabisystems.com>
ec20cffb
JT
9813
9814 * config.gcc (vax-*-netbsdelf*): Enable configuration.
6d8dd940 9815 * config/elfos.h (PCC_BITFIELD_TYPE_MATTERS): Define only
ec20cffb
JT
9816 if not already defined.
9817 * config/vax/elf.h: New file.
9818 * config/vax/netbsd-elf.h: New file.
9819 * config/vax/vax.c: Include "debug.h".
9820 (vax_output_function_prologue): Add dwarf2 support. Use
9821 MAIN_NAME_P when checking for VMS_TARGET stack adjust.
9822 * config/vax/vax.h (CONST_OK_FOR_LETTER_P): Add cases for
9823 'J' [0..63], 'K' [-128..127], 'L' [-32768..32767],
9824 'M' [0..255], 'N' [0..65535], and, 'O' [-63..-1].
9825 (VAX_ISTREAM_SYNC): Remove.
9826 (INITIALIZE_TRAMPOLINE): Use gen_sync_istream.
9827 (JUMP_TABLES_IN_TEXT_SECTION): Define.
9828 (ASM_OUTPUT_REG_POP): Use reg_names for the stack pointer.
9829 (ASM_OUTPUT_ADDR_VEC_ELT): Use ASM_GENERATE_INTERNAL_LABEL
9830 and assemble_name.
9831 (ASM_OUTPUT_ADDR_DIFF_ELT): Likewise.
9832 (PRINT_OPERAND_PUNCT_VALID_P): Accept '|'.
9833 (PRINT_OPERAND): Output REGISTER_PREFIX for '|'.
9834 (INCOMING_RETURN_ADDR_RTX): Define.
9835 * config/vax/vax.md (VUNSPEC_BLOCKAGE)
9836 (VUNSPEC_SYNC_ISTREAM): Define.
9837 (blockage): Use VUNSPEC_BLOCKAGE.
9838 (sync_istream): New insn.
9839
98402002-10-01 Richard Henderson <rth@redhat.com>
9841
9842 * config/vax/vax.md (call_pop, *call_pop, call_value_pop)
9843 (*call_value_pop, call, call_value): Add dwarf2 EH support.
9844 (*call): New insn.
9845
73a73768
NS
98462002-10-01 Nathan Sidwell <nathan@codesourcery.com>
9847
9848 PR c/8083
9849 * c-typeck.c (build_c_cast): Warn about type punning which breaks
9850 type based aliasing.
9851
0645ba8f
MM
98522002-10-01 Mark Mitchell <mark@codesourcery.com>
9853
9854 * stor-layout.c (update_alignment_for_field): New function.
9855 (place_union_field): Use it.
9856 (place_field): Likewise.
6d8dd940 9857
f7e466a3
NS
98582002-10-01 Nathan Sidwell <nathan@codesourcery.com>
9859
73a73768 9860 PR other/8077
f7e466a3
NS
9861 * gcc.c (cc1_options): Add space on -auxbase-strip.
9862
bc9ec51b
JW
98632002-10-01 Jim Wilson <wilson@redhat.com>
9864
9865 * config/v850/v850.h (EPILOGUE_USES): Define.
9866
a646f6cc
AH
98672002-09-30 Andrew Haley <aph@redhat.com>
9868
6d8dd940 9869 * flow.c (insn_dead_p): When using non-call-exceptions, don't
a646f6cc
AH
9870 eliminate insns that may trap.
9871 * cse.c (insn_live_p): Likewise.
9872
3f7967e3
RS
98732002-10-01 Richard Sandiford <rsandifo@redhat.com>
9874
9875 * config/mips/mips.h (PROCESSOR_R4121): Rename to PROCESSOR_R4120.
9876 (TARGET_MIPS4121): Rename to TARGET_MIPS4120.
9877 * config/mips/mips.c (mips_cpu_info): Rename vr4121 to vr4120.
9878 * config/mips/mips.md: Apply same renaming here.
9879
41f9efba
RS
98802002-10-01 Richard Sandiford <rsandifo@redhat.com>
9881
9882 * config/mips/mips.c (PROCESSOR_R4320, TARGET_MIPS4320): Remove.
9883 (GENERATE_MULT3_SI): Remove use of TARGET_MIPS4320.
9884 * config/mips/mips.c (mips_cpu_info): Remove vr4320 entry.
9885 * config/mips/mips.md (define_attr cpu): Remove r4320.
9886 Remove vr4320 scheduler and uses of TARGET_MIPS4320.
9887
366356d3
RS
98882002-10-01 Richard Sandiford <rsandifo@redhat.com>
9889
9890 * config/mips/mips.c (mips16_strings): New variable.
9891 (mips_output_function_epilogue): Clear the SYMBOL_REF_FLAG of every
9892 symbol in mips16_strings. Free the list.
9893 (mips_encode_section_info): Keep track of local strings.
9894
8ab907e8
RS
98952002-10-01 Richard Sandiford <rsandifo@redhat.com>
9896
9897 * config/mips/mips.md (bunge, bltgt, bungt): New define_expands.
9898 (sordered_df, sordered_sf): Remove.
9899 * config/mips/mips.c (get_float_compare_codes): New fn.
9900 (gen_int_relational, gen_conditional_move): Use it.
9901
d12b8c85
RS
99022002-10-01 Richard Sandiford <rsandifo@redhat.com>
9903
9904 * config/mips/mips-protos.h (mips_emit_fcc_reload): Declare.
9905 * config/mips/mips.h (PREDICATE_CODES): Add fcc_register_operand.
9906 * config/mips/mips.c (fcc_register_operand): New function.
9907 (mips_emit_fcc_reload): New function, extracted from reload_incc.
9908 (override_options): Allow TFmode values in float registers
9909 if ISA_HAS_8CC.
9910 * cnfig/mips/mips.md (reload_incc): Change destination prediate
9911 to fcc_register_operand. Remove misleading source constraint.
9912 Use mips_emit_fcc_reload.
9913 (reload_outcc): Duplicate reload_incc.
9914
4977bab6
ZW
99152002-09-30 Zack Weinberg <zack@codesourcery.com>
9916
9917 * gcc.c (validate_switches): Handle all new forms of spec
9918 syntax introduced recently. Now returns a char *.
9919 (validate_all_switches): Repetitive logic broken out to...
9920 (validate_switches_from_spec): ...here.
9921 * mklibgcc.in: Don't @-flag commands to generate .oS files.
9922
7e765675
UW
99232002-09-30 Ulrich Weigand <uweigand@de.ibm.com>
9924
9925 * longlong.h: Partially synchronize with GMP-4.1 version:
9926 Use i370 definitions also for s390.
9927 Add generic definition of umul_ppmm in terms of smul_ppmm.
9928 [s390] (umul_ppmm): Remove.
9929 [s390] (smul_ppmm): Fix incorrect assembler constraints.
9930 [s390] (smul_ppmm, sdiv_qrnnd): Rename __xx to __x.
9931
89f6025d
BW
99322002-09-30 Bob Wilson <bob.wilson@acm.org>
9933
9934 * config/xtensa/xtensa.h (REG_CLASS_NAMES, REG_CLASS_CONTENTS):
9935 Add new RL_REGS register class.
9936 (PREFERRED_RELOAD_CLASS, PREFERRED_OUTPUT_RELOAD_CLASS):
ee6ff319 9937 Call xtensa_preferred_reload_class for both input and output reloads.
89f6025d
BW
9938 * config/xtensa/xtensa.c (xtensa_regno_to_class): Use new RL_REGS class.
9939 (xtensa_preferred_reload_class): Handle output reloads; use RL_REGS
9940 instead of either AR_REGS or GR_REGS classes.
9941 (xtensa_secondary_reload_class): Use new RL_REGS class.
9942 * config/xtensa/xtensa-protos.h (xtensa_preferred_reload_class): Update.
9943
7830ba7b
JDA
99442002-09-30 John David Anglin <dave@hiauly1.hia.nrc.ca>
9945
9946 * pa.c (hppa_encode_label): Don't drop '*' from function labels.
9947 (pa_strip_name_encoding): Strip '@' and '*', in that order.
9948 * pa.h (ASM_OUTPUT_LABELREF): Output user_label_prefix except when
9949 there is a '*' prefix in NAME.
9950
344b78b8
JH
9951Mon Sep 30 21:33:23 CEST 2002 Jan Hubicka <jh@suse.cz>
9952
9953 * reload.c (push_reload): Handle subregs and secondary memory.
9954 * reload1.c (gen_reload): Likewise.
9955
9956 * jump.c (reg_or_subregno): New function.
9957 * rtl.h (reg_or_subregno): Declare
9958 * unroll.c (find_splittable_givs): Handle subregs.
9959
17bbb839
MM
99602002-09-30 Mark Mitchell <mark@codesourcery.com>
9961
9962 * store-layout.c (finish_record_layout): Add free_p parameter.
9963 (layout_type): Pass it.
9964 * tree.h (finish_record_layout): Update prototype.
92e89ef0 9965
48ddd46c
JH
9966Mon Sep 30 14:57:18 CEST 2002 Jan Hubicka <jh@suse.cz>
9967
9968 * i386.h (TARGET_CPP_CPU_BUILTINS): Define __SSE_MATH__.
9969
9970 * gcse.c (cprop_jump): Check that the register has not
9971 been modified
9972 (cprop_jump): Likewise.
9973
b93a0fe6
RE
99742002-09-30 Richard Earnshaw <rearnsha@arm.com>
9975
9976 * arm.h (BASE_REG_CLASS): Always return LO_REGS for Thumb.
9977 (MODE_BASE_REG_CLASS, case Thumb): Only return BASE_REGS if we know
9978 that we have a SImode access, and only then if reload hasn't completed;
9979 for all other cases, use LO_REGS.
9980
4977bab6
ZW
99812002-09-29 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
9982
9983 * openbsd.h: Fix typo in last change.
9984
98ee7e6c
RH
99852002-09-29 Richard Henderson <rth@redhat.com>
9986
9987 * real.c (real_from_string): Apply sign last. Tidy exponent handling.
9988
ccf7aef4
RH
99892002-09-29 Richard Henderson <rth@redhat.com>
9990
b5371c18 9991 PR c/8002
ccf7aef4
RH
9992 * combine.c (force_to_mode): Handle FLOAT_MODE destinations
9993 for CONST_INT.
9994
d454e75a
DE
99952002-09-29 David Edelsohn <edelsohn@gnu.org>
9996
9997 * real.h (ibm_extended_format): Declare.
9998 * real.c (encode_ibm_extended, decode_ibm_extended): New
9999 functions.
10000
89b06540
KG
100012002-09-29 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
10002
10003 * darwin-protos.h (darwin_asm_output_dwarf_delta): Prototype.
10004
10005 * ia64.c (ia64_hpux_asm_file_end): Const-ify.
10006
6ca6193b
JDA
100072002-09-29 John David Anglin <dave@hiauly1.hia.nrc.ca>
10008
10009 * expmed.c (extract_bit_field): Fix bit-field extraction from SUBREGs.
10010
991b6592
KH
100112002-09-29 Kazu Hirata <kazu@cs.umass.edu>
10012
10013 * builtins.def: Fix comment formatting.
10014 * c-common.def: Likewise.
10015 * cfgcleanup.c: Likewise.
10016 * combine.c: Likewise.
10017 * gengtype.c: Likewise.
10018 * params.def: Likewise.
10019 * predict.def: Likewise.
10020 * rtl.def: Likewise.
10021 * stab.def: Likewise.
10022 * stor-layout.c: Likewise.
10023 * tree.def: Likewise.
10024 * config/darwin.c: Likewise.
10025 * config/darwin.h: Likewise.
10026 * config/dbxcoff.h: Likewise.
10027 * config/elfos.h: Likewise.
10028 * config/fp-bit.c: Likewise.
10029 * config/freebsd-spec.h: Likewise.
10030 * config/interix.h: Likewise.
10031 * config/libgloss.h: Likewise.
10032 * config/linux-aout.h: Likewise.
10033 * config/linux.h: Likewise.
10034 * config/lynx-ng.h: Likewise.
10035 * config/lynx.h: Likewise.
10036 * config/netbsd-aout.h: Likewise.
10037 * config/netbsd.h: Likewise.
10038 * config/netware.h: Likewise.
10039 * config/psos.h: Likewise.
10040 * config/ptx4.h: Likewise.
10041
43aa4e05
KH
100422002-09-28 Kazu Hirata <kazu@cs.umass.edu>
10043
10044 * ChangeLog.4: Fix typos.
10045 * ChangeLog.6: Likewise.
10046 * FSFChangeLog.10: Likewise.
10047 * genattrtab.c: Fix comment typos.
10048 * haifa-sched.c: Likewise.
10049 * real.c: Likewise.
10050 * tree.h: Likewise.
10051 * config/arm/arm.c: Likewise.
10052 * config/arm/crti.asm: Likewise.
10053 * config/arm/crtn.asm: Likewise.
10054 * config/frv/frv.c: Likewise.
10055 * config/frv/frv.md: Likewise.
10056 * config/h8300/h8300.md: Likewise.
10057 * config/i386/rtemself.h: Likewise.
10058 * config/ia64/unwind-ia64.c: Likewise.
10059 * config/ip2k/ip2k.h: Likewise.
10060 * config/m88k/m88k.c: Likewise.
10061 * config/m88k/m88k.md: Likewise.
10062 * config/mips/sr71k.md: Likewise.
10063 * config/mmix/mmix.c: Likewise.
10064 * config/rs6000/rs6000.c: Likewise.
10065 * config/sh/sh.md: Likewise.
10066
13e8651c
TR
100672002-09-26 Theodore A. Roth <troth@verinet.com>
10068
92e89ef0
ZW
10069 * config/avr/avr.c: Eliminate use of _PC_ in pc relative insns.
10070 * config/avr/avr.md: Ditto.
13e8651c 10071
57147be1
ZW
100722002-09-27 Alexander N. Kabaev <ak03@gte.com>
10073
10074 PR preprocessor/8055
10075 * cppmacro.c (stringify_arg): Do not overflow the buffer
10076 with the terminating NUL when the argument to be stringified
10077 has no tokens.
10078
5d0f3df7
RH
100792002-09-27 Richard Henderson <rth@redhat.com>
10080
10081 * unroll.c (simplify_cmp_and_jump_insns): New.
10082 (unroll_loop): Use it. Use simplify_gen_foo+force_operand
10083 instead of expand_simple_foo.
10084
3dfda826
RH
100852002-09-27 Richard Henderson <rth@redhat.com>
10086
10087 PR optimization/7520
10088 * cfganal.c (flow_active_insn_p): New.
10089 (forwarder_block_p): Use it.
10090
23b8ba81
RH
100912002-09-27 Richard Henderson <rth@redhat.com>
10092
10093 * emit-rtl.c (active_insn_p): Revert last change.
10094
dce81a1a
JJ
100952002-09-27 Jakub Jelinek <jakub@redhat.com>
10096
10097 * doc/extend.texi (tls_model): Document.
10098 * varasm.c (decl_tls_model): New.
10099 * c-common.c (handle_tls_model_attribute): New.
10100 (c_common_attribute_table): Add tls_model.
10101 * config/alpha/alpha.c (alpha_encode_section_info): Use
10102 decl_tls_model.
10103 * flags.h (enum tls_model, flag_tls_default): Move...
10104 * tree.h (enum tls_model, flag_tls_default): ...here.
10105 (decl_tls_model): New prototype.
10106 * config/ia64/ia64.c (ia64_encode_section_info): Likewise.
10107 * config/i386/i386.c (ix86_encode_section_info): Likewise.
10108 * config/i386/i386.md (tls_global_dynamic, tls_local_dynamic_base):
10109 Allow !flag_pic.
10110
0e9e1e0a
KH
101112002-09-27 Kazu Hirata <kazu@cs.umass.edu>
10112
10113 * LANGUAGES: Follow spelling conventions.
10114 * rtl.def: Likewise.
10115 * sbitmap.c: Likewise.
10116 * sched-int.h: Likewise.
10117 * sched-rgn.c: Likewise.
10118 * sibcall.c: Likewise.
10119 * simplify-rtx.c: Likewise.
10120 * ssa.c: Likewise.
10121 * stab.def: Likewise.
10122 * stmt.c: Likewise.
10123 * stor-layout.c: Likewise.
10124 * target.h: Likewise.
10125 * timevar.c: Likewise.
10126 * toplev.c: Likewise.
10127 * tree-dump.c: Likewise.
10128 * tree-inline.c: Likewise.
10129 * tree.c: Likewise.
10130 * tree.def: Likewise.
10131 * tree.h: Likewise.
10132 * unroll.c: Likewise.
10133 * varasm.c: Likewise.
10134 * vmsdbgout.c: Likewise.
10135 * treelang/treelang.texi: Likewise.
10136 * treelang/treetree.c: Likewise.
10137
b9b575e6
KH
101382002-09-27 Kazu Hirata <kazu@cs.umass.edu>
10139
10140 * config/h8300/h8300.c (compute_saved_regs): Use a macro
10141 instead of a hard register number.
10142 (get_shift_alg): Use an enumerated type instead of numbers.
10143 (h8300_shift_needs_scratch_p): Likewise.
10144
4977bab6
ZW
101452002-09-26 Kazu Hirata <kazu@cs.umass.edu>
10146
10147 * varasm.c (force_data_section): Remove.
10148 (assemble_constant_align): Likewise.
10149 * output.h: Remove corresponding prototypes.
10150
101512002-09-26 Roger Sayle <roger@eyesopen.com>
10152
10153 * stmt.c (expand_exit_loop_if_false): Expand a simple conditional
10154 jump, if the loop to exit is the top of the current nesting stack.
10155
101562002-09-26 Torbjorn Granlund <tege@swox.com>
10157
10158 * libgcc2.c (fixunsdfdi, fixunssfdi): Rewrite, avoiding `long long'
10159 arithmetic.
10160
99a32567
DM
101612002-09-26 David S. Miller <davem@redhat.com>
10162
10163 PR optimization/7335
10164 * calls.c (emit_library_call_value_1): Passing args by reference
10165 converts a CONST function into a PURE one.
10166
67cef334
DE
101672002-09-26 David Edelsohn <edelsohn@gnu.org>
10168
10169 * dbxout.c (FORCE_TEXT): Switch to current_function_decl, not
10170 text_section.
57147be1 10171 * xcoffout.h (DBX_STATIC_BLOCK_START): Remove explicit change to
67cef334
DE
10172 text section.
10173 * config/rs6000/rs6000.c (rs6000_override_options): Allow
10174 function-sections and data-sections functionality on AIX.
10175
101762002-09-26 David Edelsohn <edelsohn@gnu.org>
10177 Dale Johannesen <dalej@apple.com>
10178
10179 * config/rs6000/rs6000.c (rs6000_emit_move): Insert zero-extend
10180 in RTL for sub-word loads from memory.
10181
c2310f51
RH
101822002-09-26 Richard Henderson <rth@redhat.com>
10183
10184 PR c/7160
10185 * sched-deps.c (sched_analyze_insn): Make clobber insns depend
10186 on call insns.
10187
7847d627
RH
101882002-09-26 Richard Henderson <rth@redhat.com>
10189
10190 * emit-rtl.c (const_double_htab_eq): Remove unused variable.
10191
cde0ce6e
CL
101922002-09-26 Chris Lattner <sabre@nondot.org>
10193
10194 * ssa.c (rename_insn_1): Handle RENAME_NO_RTX correctly when
10195 handling undefined values.
10196
03a62672
RH
101972002-09-26 Richard Henderson <rth@redhat.com>
10198
5fd452e8 10199 PR opt/7520
03a62672
RH
10200 * emit-rtl.c (active_insn_p): Consider a clobber of the
10201 function return value to be active even after reload.
10202
b5a77fef
AM
102032002-09-27 Alan Modra <amodra@bigpond.net.au>
10204
10205 * doloop.c (doloop_modify_runtime <biv skips initial incr>): Adjust
10206 by absolute loop increment, not loop increment.
10207
40f03658
KH
102082002-09-26 Kazu Hirata <kazu@cs.umass.edu>
10209
10210 * c-common.h: Follow spelling conventions.
10211 * cpplex.c: Likewise.
10212 * cpplib.h: Likewise.
10213 * gthr-dce.h: Likewise.
10214 * gthr-posix.h: Likewise.
10215 * optabs.c: Likewise.
10216 * output.h: Likewise.
10217 * profile.c: Likewise.
10218 * protoize.c: Likewise.
10219 * ra-rewrite.c: Likewise.
10220 * real.c: Likewise.
10221 * recog.c: Likewise.
10222 * reg-stack.c: Likewise.
10223 * regclass.c: Likewise.
10224 * regmove.c: Likewise.
10225 * reload.c: Likewise.
10226 * reload.h: Likewise.
10227 * reload1.c: Likewise.
10228 * reorg.c: Likewise.
10229 * resource.c: Likewise.
10230 * rtl.h: Likewise.
10231 * rtlanal.c: Likewise.
10232
ee8a73d6
SE
102332002-09-26 Steve Ellcey <sje@cup.hp.com>
10234
10235 * config/ia64/ia64.c (ia64_expand_load_address): Ensure correct mode
10236 for symbol address.
10237
2eb2bbdc
EC
102382002-09-24 Eric Christopher <echristo@redhat.com>
10239
57147be1
ZW
10240 * config/mips/elf.h: Add HANDLE_SYSV_PRAGMA.
10241 * config/mips/elf64.h: Ditto.
2eb2bbdc 10242
0ab38418
EC
102432002-09-24 Eric Christopher <echristo@redhat.com>
10244
57147be1 10245 * except.c (expand_builtin_extract_return_address): Handle case
0ab38418
EC
10246 where Pmode != ptr_mode.
10247
68bb91b1
SE
102482002-09-26 Steve Ellcey <sje@cup.hp.com>
10249
10250 * config/ia64/hpux.h (ASM_OUTPUT_EXTERNAL_LIBCALL): New
10251
5429802d
SE
102522002-09-26 Steve Ellcey <sje@cup.hp.com>
10253
10254 * config/ia64/hpux.h (TARGET_DEFAULT): Include TARGET_ILP32.
10255
855c3a2e
IS
102562002-09-26 Igor Shevlyakov <igor@microunity.com>
10257
10258 * combine.c (simplify_set): Don't call to force_to_mode if size
10259 of integer type is larger than HOST_BITS_PER_WIDE_INT.
10260
2d556baf
JJ
102612002-09-26 Janis Johnson <janis187@us.ibm.com>
10262
10263 * Makefile.in (qmtest-g++): Fix file path.
10264
1717e19e
UW
102652002-09-26 Ulrich Weigand <uweigand@de.ibm.com>
10266
0ab38418 10267 * expr.c (expand_expr) [MINUS_EXPR]: Convert A - const to
1717e19e
UW
10268 A + (-const) on RTX level, even for unsigned types.
10269
6cabe79e
UW
102702002-09-26 Ulrich Weigand <uweigand@de.ibm.com>
10271
10272 * reload.c (dup_replacements): New function.
10273 (find_reloads): Use it to duplicate replacements at the top level
10274 of match_dup operands.
10275
0855247a
MB
102762002-09-26 Miles Bader <miles@gnu.org>
10277
10278 * v850.md ("length"): Change default value to 4.
10279
6335b0aa
KH
102802002-09-26 Kazu Hirata <kazu@cs.umass.edu>
10281
10282 * ChangeLog.1: Follow spelling conventions.
10283 * ChangeLog.4: Likewise.
10284 * ChangeLog.6: Likewise.
10285 * FSFChangeLog.11: Likewise.
10286 * doc/cpp.texi: Likewise.
10287 * doc/invoke.texi: Likewise.
10288 * doc/tm.texi: Likewise.
10289
09818236
NC
102902002-09-26 Nick Clifton <nickc@redhat.com>
10291
10292 * config.gcc: Add x prefix to v850e case for handling
10293 --with-cpu=v850e.
10294
4977bab6
ZW
102952002-09-25 Zack Weinberg <zack@codesourcery.com>
10296
10297 * gcc.c (input_suffix_matches, switch_matches,
10298 mark_matching_switches, process_marked_switches,
10299 process_brace_body): New functions - split from handle_braces.
10300 (handle_braces): Rewrite; handle %{S:X;T:Y;:D} syntax; accept
10301 and ignore whitespace in more places.
10302 (specs documentation comment): Document %{S:X;T:Y;:D}.
10303 Clarify other %{...} docs.
10304 * doc/invoke.texi: Document %{S:X;T:Y;:D}. Clarify other
10305 %{...} docs.
10306
10307 * config/arm/aof.h (LINK_SPEC): Change %{ov*,*} to %{ov*}.
10308 * config/rs6000/sysv4.h: Use N-way choice spec syntax.
10309
8a3996fd
DM
103102002-09-25 David S. Miller <davem@redhat.com>
10311
10312 PR target/7842
10313 * config/sparc/sparc.c (set_extends): SImode ASHIFT does not
10314 extend.
10315
8580f7a0
RH
103162002-09-25 Richard Henderson <rth@redhat.com>
10317
10318 * emit-rtl.c (const_double_htab_eq): Distinguish integer and
10319 fp CONST_DOUBLE; use real_identical.
10320
956d9305
MM
103212002-09-25 Mark Mitchell <mark@codesourcery.com>
10322
10323 * doc/invoke.texi: Add more -Wabi examples.
10324
3ccbe819
RS
103252002-09-25 Richard Sandiford <rsandifo@redhat.com>
10326
10327 * config/mips/mips.h (TARGET_MIPS4100): Add missing bracket.
10328
4977bab6
ZW
103292002-09-24 Nathan Sidwell <nathan@codesourcery.com>
10330
10331 * profile.c (end_branch_prob): Only look for __gcov_init on
10332 weak-enabled native compilers.
10333
2106e42a
DC
103342002-09-24 Denis Chertykov <denisc@overta.ru>
10335
10336 * config/ip2k/ip2k.c (function_epilogue): Fix wrong numbers in
10337 cases of optimizing "add sp,w" to "inc sp".
10338
58e60158
AN
103392002-09-24 Adam Nemet <anemet@lnxw.com>
10340
57147be1
ZW
10341 * config/arm/arm.c (thumb_unexpanded_epilogue): Don't generate
10342 epilogue for naked functions.
58e60158 10343
59be6073 103442002-09-24 Adam Nemet <anemet@lnxw.com>
57147be1 10345 Nick Clifton <nickc@redhat.com>
59be6073
AN
10346
10347 * config/arm/arm.h (THUMB_FUNCTION_PROFILER): Remove.
10348 (FUNCTION_PROFILER): Only invoke THUMB_FUNCTION_PROFILER if it
10349 is defined.
10350
100c7420
UW
103512002-09-24 Ulrich Weigand <uweigand@de.ibm.com>
10352
10353 * config/s390/s390.c (preferred_la_operand_p): New function.
10354 * config/s390/s390-protos.h (preferred_la_operand_p): Declare it.
10355 * config/s390/s390.md ("addaddr_esame", "*la_ccclobber"): Replace by ...
10356 ("*la_64_cc", "*la_31_cc", splitters): ... these.
10357 ("*la_31"): Deactivate for TARGET_64BIT.
10358 ("*la_31_and", "*la_31_and_cc"): New.
10359
9fc63af5
KG
103602002-09-24 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
10361
10362 * real.h (real_value): Make `exp' explicitly signed.
10363
43a88a8c
KH
103642002-09-24 Kazu Hirata <kazu@cs.umass.edu>
10365
10366 * config/elfos.h: Follow spelling conventions.
10367 * config/alpha/alpha.h: Likewise.
10368 * config/arc/arc.h: Likewise.
10369 * config/arm/arm.md: Likewise.
10370 * config/avr/avr.h: Likewise.
10371 * config/cris/cris.md: Likewise.
10372 * config/d30v/d30v.h: Likewise.
10373 * config/frv/frv.c: Likewise.
10374 * config/frv/frv.h: Likewise.
10375 * config/h8300/h8300.c: Likewise.
10376 * config/h8300/h8300.h: Likewise.
10377 * config/h8300/h8300.md: Likewise.
10378 * config/i386/cygwin.h: Likewise.
10379 * config/i386/i386.h: Likewise.
10380 * config/i386/sysv3.h: Likewise.
10381 * config/i960/i960.h: Likewise.
10382 * config/ia64/ia64.h: Likewise.
10383 * config/ia64/ia64.md: Likewise.
10384 * config/ip2k/ip2k.h: Likewise.
10385 * config/m32r/m32r.h: Likewise.
10386 * config/m68k/m68k.h: Likewise.
10387 * config/m88k/m88k.h: Likewise.
10388 * config/mcore/mcore.c: Likewise.
10389 * config/mcore/mcore.h: Likewise.
10390 * config/mcore/mcore.md: Likewise.
10391 * config/mips/mips.h: Likewise.
10392 * config/mmix/mmix.h: Likewise.
10393 * config/mmix/mmix.md: Likewise.
10394 * config/ns32k/netbsd.h: Likewise.
10395 * config/ns32k/ns32k.h: Likewise.
10396 * config/ns32k/ns32k.md: Likewise.
10397 * config/pa/pa.h: Likewise.
10398 * config/romp/romp.h: Likewise.
10399 * config/rs6000/rs6000.h: Likewise.
10400 * config/rs6000/rs6000.md: Likewise.
10401 * config/sparc/sparc.h: Likewise.
10402 * config/stormy16/stormy-abi: Likewise.
10403 * config/stormy16/stormy16.h: Likewise.
10404 * config/vax/vax.h: Likewise.
10405
4977bab6
ZW
104062002-09-23 Kazu Hirata <kazu@cs.umass.edu>
10407
10408 * config/alpha/alpha.h: Remove commented-out macro
10409 definitions of HAVE_{POST|PRE}_{INC|DEC}REMENT.
10410 * config/avr/avr.h: Likewise.
10411 * config/d30v/d30v.h: Likewise.
10412 * config/dsp16xx/dsp16xx.h: Likewise.
10413 * config/i370/i370.h: Likewise.
10414 * config/i386/i386.h: Likewise.
10415 * config/i960/i960.h: Likewise.
10416 * config/m68k/m68k.h: Likewise.
10417 * config/m88k/m88k.h: Likewise.
10418 * config/mips/mips.h: Likewise.
10419 * config/ns32k/ns32k.h: Likewise.
10420 * config/pdp11/pdp11.h: Likewise.
10421 * config/romp/romp.h: Likewise.
10422 * config/rs6000/rs6000.h: Likewise.
10423 * config/s390/s390.h: Likewise.
10424 * config/sh/sh.h: Likewise.
10425 * config/sparc/sparc.h: Likewise.
10426 * config/stormy16/stormy16.h: Likewise.
10427 * config/vax/vax.h: Likewise.
10428
104292002-09-23 Kazu Hirata <kazu@cs.umass.edu>
10430
10431 * function.c (push_temp_slots_for_block): Remove.
10432 (push_temp_slots_for_target): Likewise.
10433 (get_target_temp_slot_level): Likewise.
10434 (set_target_temp_slot_level): Likewise.
10435 (get_first_block_beg): Likewise.
10436 * function.h: Remove corresponding prototypes.
10437
b4f94ac1
ZW
104382002-09-23 Zack Weinberg <zack@codesourcery.com>
10439
10440 * version.c (version_string): Now const char[].
10441 * version.h: Update to match.
10442
9ef1b13a
RH
104432002-09-23 Richard Henderson <rth@redhat.com>
10444
10445 * config/i386/i386.h (MASK_ACCUMULATE_OUTGOING_ARGS_SET, MASK_MMX_SET,
10446 MASK_SSE_SET, MASK_SSE2_SET, MASK_3DNOW_SET, MASK_3DNOW_A_SET): Kill.
10447 (TARGET_SWITCHES): Don't reference them.
10448 * config/i386/i386.c (override_options): Use target_flags_explicit
10449 to examine bits set by the user.
10450
ca9d6748 104512002-09-23 Dale Johannesen <dalej@apple.com>
9ef1b13a 10452
ca9d6748
DJ
10453 * dbxout.c (dbxout_parms): Set current_sym_code for params
10454 passed on stack by invisible reference.
10455
97d48e5a
RE
104562002-09-23 Richard Earnshaw <rearnsha@arm.com>
10457
10458 * arm/unknown-elf.h (ASM_OUTPUT_ALIGNED_DECL_LOCAL): Always allocate
10459 at least one byte of space.
10460
46c83bce
MM
104612002-09-23 Mark Mitchell <mark@codesourcery.com>
10462
10463 * c-common.h (flag_abi_version): Fix typo in comment.
10464 * doc/invoke.texi (flag_abi_version): Document default value.
10465
acb5d088
HPN
104662002-09-23 Hans-Peter Nilsson <hp@axis.com>
10467
10468 * doc/extend.texi (Extended Asm): Clarify that overlap between
10469 asm-declared register variables used in an asm and the asm clobber
10470 list is not allowed.
10471 * stmt.c (decl_conflicts_with_clobbers_p): New function.
10472 (expand_asm_operands): Keep track of clobbered registers. Call
10473 decl_conflicts_with_clobbers_p for each input and output operand.
10474 If no conflicts found before, also do conflict sanity check when
10475 emitting clobbers.
10476
ddf0fc72
RH
104772002-09-23 Richard Henderson <rth@redhat.com>
10478
10479 * c-common.c (cpp_define_data_format): Remove.
10480 (cb_register_builtins): Don't define __WCHAR_BIT__, __SHRT_BIT__,
10481 __INT_BIT__, __LONG_BIT__, __LONG_LONG_BIT__, __FLOAT_BIT__,
10482 __DOUBLE_BIT__, __LONG_DOUBLE_BIT__.
10483 * doc/cpp.texi: Don't document them either.
10484 (__SCHAR_MAX__, __SHRT_MAX__, __INT_MAX__, __LONG_MAX__,
10485 __LONG_LONG_MAX__): Document.
10486 (__TARGET_FLOAT_FORMAT__): Remove.
10487
a520ff95
RH
104882002-09-23 Richard Henderson <rth@redhat.com>
10489
10490 * real.c (do_multiply): Normalize U before addition.
10491
2d3e278d
MM
104922002-09-23 Mark Mitchell <mark@codesourcery.com>
10493
10494 * c-common.c (flag_abi_version): New variable.
10495 * c-common.h (flag_abi_version): Declare it.
10496 * c-opts.c (missing_arg): Add -fabi-version.
10497 (c_common_decode_option): Process -fabi-version.
10498 * doc/invoke.texi (-fabi-version): Document it.
10499 (-Wabi): Add information about bit-fields in unions.
b4f94ac1 10500
4977bab6
ZW
105012002-09-22 Roger Sayle <roger@eyesopen.com>
10502
10503 * expr.c (STORE_BY_PIECES_P): New target macro.
10504 (can_store_by_pieces, store_by_pieces): Use STORE_BY_PIECES_P
10505 instead of MOVE_BY_PIECES_P.
10506 * doc/tm.texi: Document this new macro.
10507
173b51b5
JT
105082002-09-22 Jason Thorpe <thorpej@wasabisystems.com>
10509
10510 * config/mips/netbsd.h (SUBTARGET_ASM_SPEC): Always pass -KPIC
10511 unless -fno-pic or -fno-PIC is specified.
10512
c219e1da
JDA
105132002-09-22 John David Anglin <dave@hiauly1.hia.nrc.ca>
10514
10515 * c-common.c (preprocessing_trad_p): Define.
10516 * pa-hiux.h, pa-hpux.h, pa-hpux7.h (CPP_PREDEFINES): Delete.
10517 (TARGET_OS_CPP_BUILTINS, SUBTARGET_SWITCHES): Define.
10518 * pa-hpux10.h (TARGET_OS_CPP_BUILTINS, CPP_SPEC): Define.
10519 * pa-hpux11.h (TARGET_OS_CPP_BUILTINS): Define.
10520 * pa-linux.h (CPP_PREDEFINES): Delete.
10521 (TARGET_OS_CPP_BUILTINS, CPP_SPEC): Define.
10522 * pa32-linux.h, pa64-linux.h (CPP_SPEC): Delete.
10523 * pa-osf.h, pa-pro-end.h, rtems.h (CPP_PREDEFINES): Delete.
10524 (TARGET_OS_CPP_BUILTINS): Define.
10525 * pa.h (MASK_SIO, TARGET_SIO, TARGET_PA_10): Define.
10526 (TARGET_SWITCHES): Reformat. Use N_() macro. Add SUBTARGET_SWITCHES.
10527 (SUBTARGET_SWITCHES): Provide default definition.
10528 (TARGET_OPTIONS): Reformat. Use N_() macro.
10529 (CPP_PA10_SPEC, CPP_PA11_SPEC, CPP_PA20_SPEC, CPP_64BIT_SPEC,
10530 CPP_CPU_DEFAULT_SPEC, CPP_64BIT_DEFAULT_SPEC, SUBTARGET_EXTRA_SPECS,
10531 EXTRA_SPECS, CPP_SPEC, CPLUSPLUS_CPP_SPEC, CPP_PREDEFINES): Delete.
10532 (TARGET_CPU_CPP_BUILTINS): Define.
10533 (TARGET_OS_CPP_BUILTINS): Define for BSD-like systems.
10534 * doc/invoke.texi (msio, mwsio): Document new hppa options.
10535 * doc/tm.texi (TARGET_CPU_CPP_BUILTINS): Document macro
10536 preprocessing_trad_p().
10537
65a824f6
JT
105382002-09-22 Jason Thorpe <thorpej@wasabisystems.com>
10539
10540 * doc/install.texi: Document behavior of --with-headers and
10541 --with-libs when arguments are omitted.
10542
cc2902df
KH
105432002-09-22 Kazu Hirata <kazu@cs.umass.edu>
10544
10545 * dbxout.c: Follow spelling conventions.
10546 * defaults.h: Likewise.
10547 * df.c: Likewise.
10548 * diagnostic.h: Likewise.
10549 * doloop.c: Likewise.
10550 * dwarf2out.c: Likewise.
10551 * dwarfout.c: Likewise.
10552 * emit-rtl.c: Likewise.
10553 * except.c: Likewise.
10554 * explow.c: Likewise.
10555 * expmed.c: Likewise.
10556 * expr.c: Likewise.
10557 * expr.h: Likewise.
10558 * flags.h: Likewise.
10559 * flow.c: Likewise.
10560 * fold-const.c: Likewise.
10561 * function.c: Likewise.
10562 * function.h: Likewise.
10563 * gcc.c: Likewise.
10564 * gcov-io.h: Likewise.
10565 * gcov.c: Likewise.
10566 * gcse.c: Likewise.
10567 * genattrtab.c: Likewise.
10568 * genconfig.c: Likewise.
10569 * genrecog.c: Likewise.
10570 * ggc-page.c: Likewise.
10571 * ggc.h: Likewise.
10572 * global.c: Likewise.
10573 * gthr-win32.h: Likewise.
10574 * integrate.c: Likewise.
10575 * jump.c: Likewise.
10576 * langhooks.c: Likewise.
10577 * langhooks.h: Likewise.
10578 * line-map.h: Likewise.
10579 * local-alloc.c: Likewise.
10580 * longlong.h: Likewise.
10581 * loop.c: Likewise.
10582 * loop.h: Likewise.
10583
ef49d42e
JH
10584Tue Aug 27 22:26:35 CEST 2002 Jan Hubicka <jh@suse.cz>
10585
10586 * i386.h (BIGGEST_FIELD_ALIGNMENT): Set proper default for x86_64.
10587
10588Tue Aug 27 20:07:01 CEST 2002 Jan Hubicka <jh@suse.cz>
10589
10590 * i386.c (overwrite_options): Set -mpreferred-stack-boundary to 128
10591 for -Os/TARGET_64BIT too.
10592
da7d8304
KH
105932002-09-21 Kazu Hirata <kazu@cs.umass.edu>
10594
10595 * ChangeLog: Follow spelling conventions.
10596 * ChangeLog.0: Likewise.
10597 * ChangeLog.1: Likewise.
10598 * ChangeLog.2: Likewise.
10599 * ChangeLog.3: Likewise.
10600 * ChangeLog.4: Likewise.
10601 * ChangeLog.5: Likewise.
10602 * ChangeLog.6: Likewise.
10603 * FSFChangeLog.10: Likewise.
10604 * FSFChangeLog.11: Likewise.
10605 * alias.c: Likewise.
10606 * basic-block.h: Likewise.
10607 * c-aux-info.c: Likewise.
10608 * c-common.c: Likewise.
10609 * c-common.h: Likewise.
10610 * c-decl.c: Likewise.
10611 * c-format.c: Likewise.
10612 * c-semantics.c: Likewise.
10613 * c-typeck.c: Likewise.
10614 * calls.c: Likewise.
10615 * cfganal.c: Likewise.
10616 * cfgloop.c: Likewise.
10617 * collect2.c: Likewise.
10618 * combine.c: Likewise.
10619 * conflict.c: Likewise.
10620 * cppexp.c: Likewise.
10621 * cppfiles.c: Likewise.
10622 * cpphash.h: Likewise.
10623 * cppinit.c: Likewise.
10624 * cpplex.c: Likewise.
10625 * cpplib.c: Likewise.
10626 * cpplib.h: Likewise.
10627 * cppmacro.c: Likewise.
10628 * cse.c: Likewise.
10629
330cc6c7
RE
106302002-09-21 Richard Earnshaw <rearnsha@arm.com>
10631
10632 * netbsd-aout.h (NETBSD_LINK_SPEC_AOUT): New, takes old definition of
10633 LINK_SPEC.
10634 (LINK_SPEC): Define to NETBSD_LINK_SPEC_AOUT.
10635 * arm/netbsd.h (SUBTARGET_EXTRA_SEPCS): Add NETBSD_LINK_SPEC_AOUT.
10636 (LINK_SPEC): Rework to use NETBSD_LINK_SPEC_AOUT).
10637
5b437e0f
RE
106382002-09-21 Richard Earnshaw <rearnsha@arm.com>
10639
9ee4fa29
RE
10640 PR opt/7930
10641 * cse.c (fold_rtx): Calculate old_cost before we fold each
5b437e0f
RE
10642 operand.
10643
2a15d344
RH
106442002-09-21 Richard Henderson <rth@redhat.com>
10645
10646 * c-common.c (cpp_define_data_format): Remove __GCC_LITTLE_ENDIAN__,
10647 __GCC_BIG_ENDIAN__, __TARGET_BITS_ORDER__, __TARGET_BYTES_ORDER__,
10648 __TARGET_INT_WORDS_ORDER__, __TARGET_FLOAT_WORDS_ORDER__,
10649 __TARGET_USES_VAX_F_FLOAT__, __TARGET_USES_VAX_D_FLOAT__,
10650 __TARGET_USES_VAX_G_FLOAT__, __TARGET_USES_VAX_H_FLOAT__.
10651 * doc/cpp.texi: Don't document them.
10652
3fdacdf9
RH
106532002-09-21 Richard Henderson <rth@redhat.com>
10654
10655 * c-common.c (builtin_define_float_constants): Use real_format
10656 to get the floating-point parameters.
10657
3dc85dfb
RH
106582002-09-21 Richard Henderson <rth@redhat.com>
10659
10660 * real.c (struct real_format): Move to real.h.
10661 (real_format_for_mode): Rename from fmt_for_mode; update all users;
10662 initialize with ieee defaults.
10663 (real_to_target_fmt, real_from_target_fmt): New.
10664 (ieee_single_format, ieee_double_format, ieee_extended_motorola_format,
10665 ieee_extended_intel_96_format, ieee_extended_intel_128_format,
b4f94ac1 10666 ieee_quad_format, i370_single_format, i370_double_format,
3dc85dfb
RH
10667 c4x_single_format, c4x_extended_format): Rename from s/_format//.
10668 (ieee_quad_format): Fix emin.
10669 (format_for_size, init_real_once): Remove.
10670 * real.h (struct real_format): Move from real.c.
10671 (real_format_for_mode): Declare.
10672 (real_to_target_fmt, real_from_target_fmt): Declare.
10673 (ieee_single_format, ieee_double_format, ieee_extended_motorola_format,
10674 ieee_extended_intel_96_format, ieee_extended_intel_128_format,
10675 ieee_quad_format, vax_f_format, vax_d_format, vax_g_format,
10676 i370_single_format, i370_double_format, c4x_single_format,
10677 c4x_extended_format): Declare.
10678 * toplev.c (do_compile): Don't call init_real_once.
10679
10680 * defaults.h (INTEL_EXTENDED_IEEE_FORMAT): Remove.
10681 * doc/tm.texi (INTEL_EXTENDED_IEEE_FORMAT): Remove.
10682
10683 * config/alpha/alpha.h (TARGET_FLOAT_FORMAT): Define.
10684 * config/alpha/osf5.h (LONG_DOUBLE_TYPE_SIZE): 64, if vax mode.
10685 * config/alpha/alpha.c (override_options): Set real_format_for_mode
10686 for VAX, if enabled.
10687
10688 * config/c4x/c4x.c (c4x_override_options): Set real_format_for_mode
10689 for C4X.
10690
10691 * config/i370/i370.h (OVERRIDE_OPTIONS): New.
10692 * config/i370/i370.c (override_options): New.
10693 * config/i370/i370-protos.h: Update.
10694
10695 * config/i386/i386.c (override_options): Set real_format_for_mode
10696 for Intel 80-bit extended.
10697 * config/i386/i386.h (INTEL_EXTENDED_IEEE_FORMAT): Remove.
10698
10699 * config/i960/i960.h (LONG_DOUBLE_TYPE_SIZE): Mind -mlong-double-64.
10700 (OVERRIDE_OPTIONS): Move code...
10701 * config/i960/i960.c (i960_initialize): ... here. Set
10702 real_format_for_mode for Intel 80-bit extended.
10703
10704 * config/ia64/ia64.c (ia64_override_options): Set real_format_for_mode
10705 for Intel 80-bit extended, if enabled.
10706
10707 * config/m68k/m68k.c (override_options): Set real_format_for_mode
b4f94ac1 10708 for Motorola 96-bit extended.
3dc85dfb
RH
10709
10710 * config/vax/vax.h (OVERRIDE_OPTIONS): New.
10711 * config/vax/vax.c (override_options): New.
10712 * config/vax/vax-protos.h: Update.
10713
42a6388c
AM
107142002-09-21 Alan Modra <amodra@bigpond.net.au>
10715
84d7dd4a
AM
10716 * config/rs6000/rs6000.md (builtin_setjmp_receiver): Add
10717 #if TARGET_MACHO.
10718
42a6388c
AM
10719 * config/rs6000/rs6000.md (floatdisf2_internal2): Combine
10720 insns. Supply missing clobber of scratch reg.
10721
a0ab749a
KH
107222002-09-20 Kazu Hirata <kazu@cs.umass.edu>
10723
10724 * config/m32r/m32r.c: Follow spelling conventions.
10725 * config/m32r/m32r.h: Likewise.
10726 * config/m32r/m32r.md: Likewise.
10727 * config/m68k/m68k.c: Likewise.
10728 * config/m88k/m88k.c: Likewise.
10729 * config/mcore/mcore.c: Likewise.
10730 * config/mips/mips.c: Likewise.
10731 * config/mips/mips.h: Likewise.
10732 * config/mmix/mmix.c: Likewise.
10733 * config/mn10200/mn10200.c: Likewise.
10734 * config/ns32k/ns32k.h: Likewise.
10735 * config/pa/pa.c: Likewise.
10736 * config/pa/pa64-linux.h: Likewise.
10737 * config/pdp11/pdp11.h: Likewise.
10738 * config/romp/romp.c: Likewise.
10739 * config/romp/romp.h: Likewise.
10740 * config/rs6000/eabi.asm: Likewise.
10741 * config/rs6000/linux64.h: Likewise.
10742 * config/rs6000/rs6000.c: Likewise.
10743 * config/rs6000/rs6000.h: Likewise.
10744 * config/rs6000/rs6000.md: Likewise.
10745 * config/rs6000/sysv4.h: Likewise.
10746 * config/rs6000/xcoff.h: Likewise.
10747
2f0da74c
JW
107482002-09-20 Jim Wilson <wilson@redhat.com>
10749
10750 * config/v850/v850/lib1funcs.asm (__muldi3): Change r5 to r28.
10751
dea73790
JJ
107522002-09-20 Jakub Jelinek <jakub@redhat.com>
10753
10754 * config/i386/i386.md (UNSPEC_GOTNTPOFF, UNSPEC_INDNTPOFF): New.
10755 * config/i386/i386.c (legitimate_pic_address_disp_p): Handle
10756 UNSPEC_GOTNTPOFF and UNSPEC_INDNTPOFF like UNSPEC_GOTTPOFF.
10757 (legitimate_address_p): Likewise.
10758 (legitimize_address): Use @gotntpoff and @indntpoff.
10759 (output_pic_addr_const): Handle UNSPEC_GOTNTPOFF and UNSPEC_INDNTPOFF.
10760 (output_addr_const_extra): Likewise.
10761
a9b2f059
JW
107622002-09-20 Jim Wilson <wilson@redhat.com>
10763
10764 * combine.c (try_combine): When split an instruction pair, where the
10765 first has a sign_extend src, verify that the src and dest modes match.
10766
1f7422bd
RH
107672002-09-20 Richard Henderson <rth@redhat.com>
10768
10769 * config/mips/mips.c (dfhigh, dflow, sfhigh, sflow): Remove.
10770 (override_options): Do not initialize them.
10771 (mips_const_double_ok): Allow no fp constants except zero,
10772 and not even that for mips16.
10773 (const_float_1_operand): Use dconst1.
10774 * config/mips/mips.md (movsf, movsf_internal1, movsf_internal2,
10775 movdf, movdf_internal1, movdf_internal1a, movdf_internal2):
6d8dd940 10776 Don't allow arbitrary constants; fix predicates and C constraint.
1f7422bd 10777
56941bf2
NB
107782002-09-20 Neil Booth <neil@daikokuya.co.uk>
10779
10780 * cppmacro.c: Don't warn about function-like macros without
27eba309 10781 '(' during pre-expansion.
56941bf2 10782
66a0dfeb
JW
107832002-09-20 Jim Wilson <wilson@redhat.com>
10784
10785 * config/v850/v850.c (current_function_anonymous_args): Delete.
10786 (expand_prologue): Use current_function_args_info.anonymous_args.
10787 (expand_epilogue): Delete use of current_function_anonymous_args.
10788 * config/v850/v850.h (struct cum_arg): Add anonymous_args field.
10789 (INIT_CUMULATIVE_ARGS): Clear anonymous_args field.
10790 (current_function_anonymous_args): Delete extern declaration.
10791 (SETUP_INCOMING_VARARGS): Set anonymous_args field.
10792
97b23853
GK
107932002-09-20 Geoffrey Keating <geoffk@apple.com>
10794
f51eee6a
GK
10795 * config/rs6000/rs6000.c (rs6000_emit_prologue): Update for change
10796 to load_macho_picbase.
10797 * config/rs6000/rs6000.md: Document Darwin-specific unspec IDs.
10798 (load_macho_picbase): Take the symbol to use as a parameter.
10799 (macho_correct_pic): New insn.
10800 (builtin_setjmp_reciever): On Darwin, restore the PIC register.
10801
97b23853
GK
10802 * config/rs6000/rs6000.h (ELIMINABLE_REGS): Use
10803 RS6000_PIC_OFFSET_TABLE_REGNUM rather than hardcoding 30.
10804 (CAN_ELIMINATE): Likewise.
10805 (INITIAL_ELIMINATION_OFFSET): Likewise.
10806 (TOC_REGISTER): Likewise.
10807
46b33600
RH
108082002-09-20 Richard Henderson <rth@redhat.com>
10809
10810 * real.c (real_hash): New.
10811 * real.h: Declare it.
10812 * cse.c (canon_hash): Use it.
10813 * cselib.c (hash_rtx): Likewise.
10814 * emit-rtl.c (const_double_htab_hash): Likewise.
10815 * rtl.h (CONST_DOUBLE_REAL_VALUE): New.
10816 * varasm.c (struct rtx_const): Reduce vector size; separate
10817 integer and fp vectors.
10818 (HASHBITS): Remove.
10819 (const_hash_1): Rename from const_hash. Use real_hash. Do not
10820 take modulus MAX_HASH_TABLE.
10821 (const_hash): New. Do take modulus MAX_HASH_TABLE.
10822 (output_constant_def): Do not take modulus MAX_HASH_TABLE.
10823 (SYMHASH): Don't use HASHBITS.
10824 (decode_rtx_const): Copy only active bits from REAL_VALUE_TYPE.
10825 Fix CONST_VECTOR thinko wrt fp vectors. Fix kind comparison.
10826 (simplify_subtraction): Fix kind comparison.
10827 (const_hash_rtx): Return unsigned int. Don't use HASHBITS.
10828 Use a union to pun integer array.
10829 * config/rs6000/rs6000.c (rs6000_hash_constant): Use real_hash;
10830 only hash two words of integral CONST_DOUBLE.
10831
40ad65d0
SE
108322002-09-20 Steve Ellcey <sje@cup.hp.com>
10833
10834 * config/ia64/hpux.h (STARTFILE_SPEC): Modify.
10835 (STARTFILE_PREFIX_SPEC): New.
10836 (LINK_SPEC): Modify.
10837 (LIB_SPEC): Modify.
10838 (LIBGCC_SPEC): New.
10839
600f3392
JJ
108402002-09-20 Jakub Jelinek <jakub@redhat.com>
10841
10842 * config/i386/i386.c (legitimate_pic_address_disp_p): Allow
10843 UNSPEC_NTPOFF and UNSPEC_DTPOFF to be offsetted by constant.
10844
c1ff6200
JD
108452002-09-20 Jeroen Dobbelaere <jeroen.dobbelaere@acunia.com>
10846
10847 * config/arm/arm.md (sign_extract_onebit, not_signextract_onebit):
10848 Add clobber of the condition code register.
10849
60b78700
RH
108502002-09-20 Richard Henderson <rth@redhat.com>
10851
10852 * real.c (do_fix_trunc): Static.
10853 (encode_ieee_single, encode_ieee_double, encode_ieee_extended,
10854 encode_ieee_quad, encode_vax_f, encode_vax_d, encode_vax_g,
10855 encode_i370_single, encode_i370_double, encode_c4x_single,
10856 encode_c4x_extended): Add default abort case.
10857
0ee6fdb5
RH
108582002-09-20 Richard Henderson <rth@redhat.com>
10859
10860 * real.h (enum real_value_class, SIGNIFICAND_BITS, EXP_BITS,
10861 MAX_EXP, SIGSZ, SIG_MSB, struct real_value): Move from real.c.
10862 (struct realvaluetype): Remove.
10863 (REAL_VALUE_TYPE): Use struct real_value.
10864 (REAL_VALUE_TYPE_SIZE): Use SIGNIFICAND_BITS.
10865 (test_real_width): New.
10866 * real.c: Global replace struct real_value with REAL_VALUE_TYPE.
10867 (real_arithmetic): Avoid hoops for REAL_VALUE_TYPE parameters.
10868 (real_compare, real_exponent, real_ldexp, real_isinf, real_isnan,
10869 real_isneg, real_isnegzero, real_identical, exact_real_inverse,
10870 real_to_integer, real_to_integer2, real_to_decimal,
10871 real_to_hexadecimal, real_from_string, real_from_integer,
10872 real_inf, real_nan, real_2expN, real_convert, real_to_target,
10873 real_from_target): Likewise.
10874 * tree.h (struct tree_real_cst): Use real_value not realvaluetype.
10875 * gengtype-yacc.y (bitfieldopt): Accept an ID as well.
10876
66d93b5a
RH
108772002-09-20 Richard Henderson <rth@redhat.com>
10878
10879 * real.h (UNKNOWN_FLOAT_FORMAT, IEEE_FLOAT_FORMAT, VAX_FLOAT_FORMAT,
10880 IBM_FLOAT_FORMAT, C4X_FLOAT_FORMAT, TARGET_FLOAT_FORMAT): Move ...
10881 * defaults.h: ... here.
10882 * config/arm/arm.h, config/avr/avr.h, config/d30v/d30v.h,
10883 config/fr30/fr30.h, config/frv/frv.h, config/ia64/ia64.h,
10884 config/ip2k/ip2k.h, config/mips/mips.h, config/stormy16/stormy16.h,
10885 config/xtensa/xtensa.h (TARGET_FLOAT_FORMAT): Remove.
10886
6ee3db61
HPN
108872002-09-20 Hans-Peter Nilsson <hp@bitrange.com>
10888
10889 * config/mmix/mmix.md ("negdf2"): Rewrite.
10890 ("*expanded_negdf2"): New.
10891
ff076520
JW
108922002-09-19 Jim Wilson <wilson@redhat.com>
10893
10894 * combine.c (simplify_set): When optimizing a subreg src with a
10895 cc0 dest, use GET_MODE (src) for mask instead of inner_mode.
10896
307f767b
DJ
108972002-09-19 Dale Johannesen <dalej@apple.com>
10898 * combine.c (make_extraction): Don't create
10899 invalid subreg.
10900
4977bab6
ZW
109012002-09-19 Roger Sayle <roger@eyesopen.com>
10902
10903 * tree.c (integer_nonzerop): New predicate for nonzero integers.
10904 * tree.h (integer_nonzerop): Add function prototype.
10905 * stmt.c (expand_end_loop): Don't rotate the loop when there
10906 are no instructions in the test, i.e. the loop is unconditional.
10907 (expand_exit_loop_if_false): Optimize RTL generation of loop
10908 tests when the condition is always true or always false.
10909 * c-semantics.c (genrtl_do_stmt): Optimize RTL generation of
10910 do-loops when the condition is always true.
10911 (genrtl_for_stmt): Optimize RTL generation of for-loops when
10912 the for-expression is empty.
10913
109142002-09-19 Zack Weinberg <zack@codesourcery.com>
10915
10916 * gcc.c (use_pipes): New flag.
10917 (process_command): Set it. Adjust check for -pipe conflicting
10918 with -time or -save-temps.
10919 (do_spec_1): Use it. Handle %|SUFFIX, %mSUFFIX, and
10920 %<SWITCH. Drop %| (without a SUFFIX).
10921 (handle_braces): Drop %{<SWITCH}, %{^SWITCH}, %{|...}.
10922 (give_switch): Third argument eliminated.
10923 (invoke_as, @assembler_with_cpp spec): Use %|.s or %m.s
10924 depending on AS_NEEDS_DASH_FOR_PIPED_INPUT.
10925 (specs documentation comment): Update.
10926
10927 * config/netbsd-aout.h, config/openbsd.h, config/ptx4.h,
10928 config/svr4.h, config/i386/freebsd-aout.h,
10929 config/m68k/netbsd-elf.h, config/m68k/netbsd.h,
10930 config/m68k/openbsd.h, config/mips/openbsd.h,
10931 config/sparc/sparc.h: Define AS_NEEDS_DASH_FOR_PIPED_INPUT
10932 instead of putting %| into ASM_SPEC and/or ASM_FINAL_SPEC.
10933 * config/avr/avr.h: Delete do-nothing ASM_FINAL_SPEC.
10934 * config/cris/cris.h: Update comment.
10935
10936 * ada/lang-specs.h: Use %(invoke_as). Straighten out
10937 error messages. Don't use %{^SWITCH}.
10938 * ada/misc.c (gnat_decode_option): Handle -I with a
10939 separate argument.
10940
10941 * f/lang-specs.h: Use %| and %m.
10942 * java/jvspec.c: Use %m and %(invoke_as). Change all
10943 uses of %{<SWITCH} to %<SWITCH.
10944
10945 * doc/invoke.texi: Update documentation of specs.
10946 * doc/tm.texi: Document AS_NEEDS_DASH_FOR_PIPED_INPUT.
10947
cc7ab9b7
UW
109482002-09-19 Ulrich Weigand <uweigand@de.ibm.com>
10949
b4f94ac1 10950 * config/s390/s390.c (addr_generation_dependency_p): Handle SUBREG
cc7ab9b7
UW
10951 and STRICT_LOW_PART within SET_DEST.
10952 * config/s390/s390.md ("*extractqi", "*extracthi"): New insns with
10953 splitters, replacing pre-reload splitters.
b4f94ac1 10954 ("*zero_extendhisi2_31", "*zero_extendqisi2_31",
cc7ab9b7
UW
10955 "*zero_extendqihi2_31"): New insns.
10956 ("*zero_extendqihi2_64"): Do not clobber CC.
10957
4977bab6
ZW
109582002-09-18 Devang Patel <dpatel@apple.com>
10959
10960 * cp/cp-tree.h: New prototype for walk_vtables().
10961 * cp/decl.c (walk_vtables_r): New function.
10962 (struct cp_binding_level): Add new members, namespaces,
10963 names_size and vtables.
10964 (add_decl_to_level): Add decl in namespaces or vtables
10965 chain, if conditions match.
10966 (walk_vtables): New function.
10967 (walk_namespaces_r): Travers separate namespace chain
10968 for namespace decls.
10969 (wrapup_globals_for_namespace): Use names_size instead
10970 of list_length().
10971 * cp/decl2.c (finish_file): Use walk_vtables() instead of
10972 walk_globals() to walk vtable decls.
10973
b64ddb88
SE
109742002-09-19 Steve Ellcey <sje@cup.hp.com>
10975
10976 * config/ia64/hpux.h (CTORS_SECTION_ASM_OP): New.
10977 (DTORS_SECTION_ASM_OP): Ditto.
10978 (READONLY_DATA_SECTION_ASM_OP): Moved.
10979 (DATA_SECTION_ASM_OP): New.
10980 (SDATA_SECTION_ASM_OP): New.
10981 (BSS_SECTION_ASM_OP): New.
10982 (SBSS_SECTION_ASM_OP): New.
10983 (TEXT_SECTION_ASM_OP): New.
10984
9cd10576
KH
109852002-09-19 Kazu Hirata <kazu@cs.umass.edu>
10986
10987 * config/fp-bit.c: Follow spelling conventions.
10988 * config/d30v/d30v.c: Likewise.
10989 * config/d30v/d30v.h: Likewise.
10990 * config/fr30/fr30.c: Likewise.
10991 * config/fr30/fr30.h: Likewise.
10992 * config/fr30/fr30.md: Likewise.
10993 * config/frv/frv.c: Likewise.
10994 * config/frv/frv.h: Likewise.
10995 * config/h8300/h8300.c: Likewise.
10996 * config/h8300/lib1funcs.asm: Likewise.
10997 * config/i370/i370.c: Likewise.
10998 * config/i386/i386.h: Likewise.
10999 * config/i386/i386.md: Likewise.
11000 * config/i386/pentium.md: Likewise.
11001 * config/i386/winnt.c: Likewise.
11002 * config/i960/i960.c: Likewise.
11003 * config/ia64/ia64.h: Likewise.
11004 * config/ip2k/ip2k.c: Likewise.
11005 * config/ip2k/ip2k.h: Likewise.
11006 * config/ip2k/ip2k.md: Likewise.
11007 * config/ip2k/libgcc.S: Likewise.
11008
fff08fd8
SC
110092002-09-19 Stephen Clarke <stephen.clarke@superh.com>
11010
11011 * config/sh/sh.h (UNSPEC_GOTOFF_P): Define.
11012 (GOTOFF_P): Extend to allow gotoff plus constant.
11013
bf3d27e6
RH
110142002-09-18 Richard Henderson <rth@redhat.com>
11015
11016 * ifcvt.c (noce_process_if_block): Correctly detect X modified
b4f94ac1 11017 with INSN_B before COND_EARLIEST. Don't check A and B for
bf3d27e6
RH
11018 modification in condition range. Reorder INSN_B for A==B properly.
11019 (if_convert): Iterate until no matches for a block.
11020
1b1f20ca
RH
110212002-09-18 Richard Henderson <rth@redhat.com>
11022
11023 * calls.c (store_one_arg): Rename default_align to parm_align;
11024 always adjust parm_align for downward padding.
11025
724838b9
RH
110262002-09-18 Richard Henderson <rth@redhat.com>
11027
11028 * toplev.c (backend_init): Move init_real_once invocation ...
11029 (do_compile): ... here.
11030
2c67b7c6
RH
110312002-09-18 Richard Henderson <rth@redhat.com>
11032
11033 * sibcall.c (optimize_sibling_and_tail_recursive_call): Also remove
11034 RTX_UNCHANGING_P markers for successful tail-recursive replacement.
11035
15769ca3
RH
110362002-09-18 Richard Henderson <rth@redhat.com>
11037
11038 * real.c (round_for_format): Collect sticky as unsigned long, not bool.
11039
678b7733
AM
110402002-09-19 Alan Modra <amodra@bigpond.net.au>
11041
11042 * config/rs6000/rs6000.md: (floatdisf2): Rename to
11043 floatdisf2_internal1.
11044 (floatdisf2): New define_expand.
11045 (floatdisf2_internal2): Likewise.
11046
c402b6bf
RH
110472002-09-18 Richard Henderson <rth@redhat.com>
11048
b4f94ac1 11049 * real.c (sticky_rshift_significand): Collect sticky as
c402b6bf
RH
11050 unsigned long, not bool.
11051
dea09b1b
UW
110522002-09-18 Ulrich Weigand <uweigand@de.ibm.com>
11053
11054 * config/s390/s390.c (s390_address_cost): New function.
11055 config/s390/s390-protos.h (s390_address_cost): Add prototype.
11056 config/s390/s390.h (ADDRESS_COST): Call s390_address_cost.
11057 (RTX_COST): Use COSTS_N_INSNS.
11058
e4850f36
DR
110592002-09-18 Douglas Rupp <rupp@gnat.com>
11060 Donn Terry <donnte@microsoft.com>
11061
11062 * stor-layout.c (place_field): Handle alignment of whole
11063 structures when MSVC compatible bitfields are involved.
11064 Change method of computing location of MS bitfields to
11065 be compatible with #pragma pack(n).
11066
11067 * tree.h (record_layout_info): Add new field
11068 remaining_in_alignment.
11069
11070 * doc/tm.texi: (TARGET_MS_BITFIELD_LAYOUT_P): Update.
4977bab6 11071 (pragma pack): Add paragraph on MSVC bitfield packing.
e4850f36 11072
872e50d3
RE
110732002-09-18 Richard Earnshaw (reanrsha@arm.com)
11074
11075 PR optimization/7967
11076 * arm.md (ne_zeroextractsi): Add clobber of the condition code
11077 register.
11078
5e7a8ee0
KH
110792002-09-18 Kazu Hirata <kazu@cs.umass.edu>
11080
9cd10576 11081 * config/s390/s390.c: Follow spelling conventions.
5e7a8ee0
KH
11082 * config/sh/lib1funcs.asm: Likewise.
11083 * config/sh/sh.c: Likewise.
11084 * config/sh/sh.h: Likewise.
11085 * config/sparc/sparc.c: Likewise.
11086 * config/sparc/sparc.h: Likewise.
11087 * config/sparc/sparc.md: Likewise.
11088 * config/stormy16/stormy16.c: Likewise.
11089 * config/stormy16/stormy16.h: Likewise.
11090 * config/v850/v850.c: Likewise.
11091 * config/v850/v850.h: Likewise.
11092 * config/vax/vax.c: Likewise.
11093 * config/vax/vax.h: Likewise.
11094
00a892b8
NC
110952002-09-18 Nick Clifton <nickc@redhat.com>
11096
11097 * config/rs60000/rs6000.c (rs6000_emit_move): Handle V1DImode moves.
11098 * config/rs60000/rs6000.c (SPE_VECTOR_MODE): Include V1DImode.
11099 * config/rs6000/spe.md (movv1di, movv1di_internal): New patterns.
11100
4977bab6
ZW
111012002-09-17 Kazu Hirata <kazu@cs.umass.edu>
11102
11103 * function.c (max_parm_reg_num): Remove.
11104 * stmt.c (in_control_zone_p, stmt_loop_nest_empty,
11105 drop_through_at_end_p, move_cleanups_up,
11106 expand_end_case_dummy, case_index_expr_type): Likewise.
11107 * stor-layout.c (pos_from_byte): Likewise.
11108 * tree.c (chain_member_value, chain_member_purpose, listify,
11109 tree_int_cst_msb, index_type_equal): Likewise.
11110 * tree.h: Remove prototypes for unused functions.
11111
bfb53001
ZW
111122002-09-17 Zack Weinberg <zack@codesourcery.com>
11113
11114 * ABOUT-GCC-NLS: Remove reference to enquire, and out-of-date
11115 statement that the only translation is to en_UK.
11116
825dda42
KH
111172002-09-17 Kazu Hirata <kazu@cs.umass.edu>
11118
11119 * config/alpha/alpha.c: Follow spelling conventions.
11120 * config/alpha/alpha.h: Likewise.
11121 * config/alpha/alpha.md: Likewise.
11122 * config/arc/arc.h: Likewise.
11123 * config/arm/arm.c: Likewise.
11124 * config/arm/arm.h: Likewise.
11125 * config/arm/arm.md: Likewise.
11126 * config/arm/pe.c: Likewise.
11127 * config/arm/unknown-elf.h: Likewise.
11128 * config/avr/avr.c: Likewise.
11129 * config/avr/avr.h: Likewise.
11130 * config/c4x/c4x.c: Likewise.
11131 * config/cris/cris.c: Likewise.
11132 * config/cris/cris.h: Likewise.
11133
8e16ab99 111342002-09-17 Samuel Figueroa <figueroa@apple.com>
825dda42 11135
8e16ab99
SF
11136 * final.c (final_scan_insn): Use new macro ASM_OUTPUT_ALIGN_WITH_NOP.
11137 * config/sparc/sparc.h (ASM_OUTPUT_ALIGN_WITH_NOP) New macro.
11138 * doc/tm.texi (ASM_OUTPUT_ALIGN_WITH_NOP) New description.
11139
ac19be7e 111402002-09-17 Dale Johannesen <dalej@apple.com>
825dda42 11141
ac19be7e
DJ
11142 * cfgcleanup.c (try_forward_edges): Do not forward a
11143 branch to just after a loop exit before loop optimization;
11144 this interfered with doloop detection.
11145
f1acdf8b
NC
111462002-09-17 Nick Clifton <nickc@redhat.com>
11147
11148 * config/arm/arm.c (output_return_instruction): Do not
11149 writeback the stack pointer when it is being loaded.
11150 (arm_output_epilogue): Likewise.
11151
24491a09
KH
111522002-09-17 Kazu Hirata <kazu@cs.umass.edu>
11153
11154 * optabs.c (prepare_cmp_insn): Let emit_library_call_value
11155 generate a pseudo reg that receives the result of a libcall.
11156 (prepare_float_lib_cmp): Likewise.
11157
e6c247e0
SE
111582002-09-17 Steve Ellcey <sje@cup.hp.com>
11159
b4f94ac1 11160 * config/ia64/elf.h: Remove CPP_PREDEFINES.
e6c247e0 11161
1074d9d4
NP
11162Tue Sep 17 13:58:04 2002 Nicola Pero <n.pero@mi.flashnet.it>
11163
11164 Fix PR/7014 and related objc bugs:
11165 * c-typeck.c (comp_target_types): Added a reflexive argument.
11166 Pass it to ObjC when/if calling objc_comptypes(). Updated all
11167 callers to provide the appropriate reflexive argument.
11168 * objc/objc-act.c (objc_comptypes): Carefully checked and fixed
11169 typechecking for all cases of comparisons and assignments,
11170 particularly the obscure and less common ones involving protocols.
11171
256e9fd2
NC
111722002-09-17 Nick Clifton <nickc@redhat.com>
11173
11174 * machmode.def (V1DImode): New mode. A single element vector.
11175 * tree.h (TI_UV1DI_TYPE, TI_V1DI_TYPE): New tree_index enums.
11176 (unsigned_V1DI_type_node, V1D1_type_node): New type nodes.
11177 * tree.c (build_common_tree_nodes_2): Build
11178 unsigned_V1DI_type_node and V1D1_type_node.
11179 * c-common.c (c_common_type_for_mode): Return
11180 unsigned_V1DI_type_node or V1D1_type_node for V1DImode.
11181 * rtl.c (class_narrowest_): Start integer vector nodes with V1DImode.
11182
838c4534
NP
11183Tue Sep 17 13:40:13 2002 Nicola Pero <n.pero@mi.flashnet.it>
11184
11185 * doc/objc.texi (Constant string objects): Extended documentation
11186 to make clear that the constant string class ivar layout is
11187 completely fixed.
b4f94ac1 11188
07532fad
RS
111892002-09-17 Roger Sayle <roger@eyesopen.com>
11190
11191 * cfgrtl.c (flow_delete_block_noexpunge): Delete orphaned
11192 NOTE_INSN_LOOP_CONT notes when deleting basic blocks.
11193
4977bab6
ZW
111942002-09-16 Volker Reichelt <reichelt@igpm.rwth-aachen.de>
11195
11196 * config/mips/mips.c (save_restore_insns): Remove unused variable.
11197 * gcc.c (make_relative_prefix): Likewise.
11198 * loop.c (check_final_value): Likewise.
11199 * jump.c (init_label_info): Remove return value.
11200 * cse.c (prev_insn): Move variable between #ifdef HAVE_cc0 ... #endif.
11201
112022002-09-16 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
11203
11204 * dsp16xx.h (ASM_FORMAT_PRIVATE_NAME): Delete.
11205 (ASM_PN_FORMAT): Define.
11206
112072002-09-16 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
11208
11209 * alpha.h, alpha/vms.h, arc.h, arm/aof.h, arm/aout.h, avr.h,
11210 c4x.h, cris.h, d30v.h, fr30.h, frv.h, h8300.h, i370.h, i386.h,
11211 i960.h, ia64.h, ip2k.h, m32r.h, m68hc11.h, m68k/3b1.h,
11212 m68k/hp320.h, m68k.h, m68k/mot3300.h, m68k/sgs.h, m68k/tower-as.h,
11213 m88k.h, mcore.h, mips.h, mmix.h, mn10200.h, mn10300.h, ns32k.h,
11214 pa.h, pdp11.h, romp.h, rs6000.h, s390/linux.h, sh.h, sparc.h,
11215 stormy16.h, v850.h, vax.h, xtensa.h (ASM_FORMAT_PRIVATE_NAME):
11216 Delete.
11217 * alpha/vms.h, h8300.h, i370.h, ia64.h, m68k/3b1.h, m68k/hp320.h,
11218 m68k/mot3300.h, m68k/sgs.h, m68k/tower-as.h, mmix.h, mn10200.h,
11219 mn10300.h, pa.h, v850.h (ASM_PN_FORMAT): Define.
11220
11221 * defaults.h (ASM_PN_FORMAT, ASM_FORMAT_PRIVATE_NAME): Define.
11222 * doc/tm.texi (ASM_FORMAT_PRIVATE_NAME): Update documentation.
11223
cb38fd88
RH
112242002-09-16 Richard Henderson <rth@redhat.com>
11225
11226 * expr.c (emit_block_move): Set memory block size as appropriate
11227 for the copy.
11228
bd055118
RH
112292002-09-16 Richard Henderson <rth@redhat.com>
11230
11231 PR fortran/3924
b4f94ac1 11232 * sdbout.c (sdbout_symbol): Don't handle offsets from a symbol.
bd055118 11233
8c317c5f
RH
112342002-09-16 Richard Henderson <rth@redhat.com>
11235
11236 * emit-rtl.c (set_mem_attributes_minus_bitpos): Adjust SIZE
11237 as well as OFFSET for BITPOS.
11238
3780101d
JG
112392002-09-16 Jeff Garzik <jgarzik@mandrakesoft.com>
11240
b4f94ac1
ZW
11241 * config.gcc: Treat winchip_c6-*|winchip2-*|c3-* as pentium-mmx.
11242 * config/i386/i386.c (processor_alias_table): Add winchip-c6,
3780101d 11243 winchip2 and c3.
b4f94ac1 11244 * doc/invoke.texi: Mention new aliases.
3780101d 11245
9dff28ab
JDA
112462002-09-16 John David Anglin <dave@hiauly1.hia.nrc.ca>
11247
11248 * calls.c (store_one_arg): Set default alignment for BLKmode arguments
11249 to BITS_PER_UNIT when ARGS_GROW_DOWNWARD and the padding direction is
11250 downward.
11251 * function.c (pad_below): Always compile.
11252 (locate_and_pad_parm): If defined ARGS_GROW_DOWNWARD, pad argument to
11253 alignment when it is not in a register or REG_PARM_STACK_SPACE is true.
11254 Pad below when the argument is not in a register and the padding
11255 direction is downward.
11256
11257 * pa-64.h (MUST_PASS_IN_STACK): Move define to pa.h.
11258 (PAD_VARARGS_DOWN): Define.
11259 * pa.c (function_arg_padding): Revise padding directions to make them
11260 compatible with the 32 and 64-bit runtime architecture documentation.
11261 (hppa_va_arg): Add code to handle variable and size zero arguments
11262 passed by reference on TARGET_64BIT. Reformat.
11263 (function_arg): Use a PARALLEL for BLKmode and aggregates args on
11264 TARGET_64BIT. Use a DImode PARALLEL for BLKmode args 5 to 8 bytes
11265 wide when !TARGET_64BIT. Move forward check for mode==VOIDmode.
11266 Add comments.
11267 * pa.h (MAX_PARM_BOUNDARY): Correct define for TARGET_64BIT.
11268 (RETURN_IN_MEMORY): Return size zero types in memory.
11269 (FUNCTION_VALUE): Return TFmode in general registers.
11270 (MUST_PASS_IN_STACK): Define.
11271 (FUNCTION_ARG_BOUNDARY): Simplify.
11272 (FUNCTION_ARG_PASS_BY_REFERENCE): Pass variable and zero sized types
11273 by reference.
11274 (FUNCTION_ARG_CALLEE_COPIES): Define to FUNCTION_ARG_PASS_BY_REFERENCE.
11275
94313f35
RH
112762002-09-16 Richard Henderson <rth@redhat.com>
11277
11278 * real.c (do_fix_trunc): New.
11279 (real_arithmetic): Call it.
11280 * simplify-rtx.c (simplify_unary_operation): Handle FIX
11281 with a floating-point result mode.
11282
1472e41c
RH
112832002-09-16 Richard Henderson <rth@redhat.com>
11284
11285 * builtin-types.def (BT_FN_FLOAT_CONST_STRING): New.
11286 (BT_FN_DOUBLE_CONST_STRING, BT_FN_LONG_DOUBLE_CONST_STRING): New.
11287 * builtins.def (__builtin_nan, __builtin_nanf, __builtin_nanl): New.
11288 (__builtin_nans, __builtin_nansf, __builtin_nansl): New.
11289 * builtins.c (fold_builtin_nan): New.
11290 (fold_builtin): Call it.
11291 * real.c (real_nan): Parse a non-empty string.
11292 (round_for_format): Fix NaN significand truncation.
11293 * real.h (real_nan): Return bool.
11294 * doc/extend.texi: Document new builtins.
11295
f354b828
JM
112962002-09-16 Jason Merrill <jason@redhat.com>
11297 Danny Smith <dannysmith@users.sourceforge.net>
11298
11299 * config/i386/winnt.c (ix86_handle_dll_attribute): Set
11300 DECL_EXTERN and TREE_PUBLIC for dllimported variables here...
11301 (i386_pe_mark_dllimport): Not here.
11302
85341ddd
NS
113032002-09-16 Nathan Sidwell <nathan@codesourcery.com>
11304
11305 * c-semantics.c (genrtl_do_stmt): Cope with NULL cond.
11306
045572c7
GK
113072002-09-16 Geoffrey Keating <geoffk@redhat.com>
11308
11309 * config/rs6000/rs6000.c (build_mask64_2_operands): Suppress
11310 warnings about unused operands when HOST_BITS_PER_WIDE_INT is
11311 < 64.
11312 (rs6000_emit_cmove): Use real_isinf not target_isinf.
11313
d57551c7
KH
113142002-09-16 Kazu Hirata <kazu@cs.umass.edu>
11315
11316 * calls.c (emit_library_call_value_1): Don't refer to
11317 hard_libcall_value.
11318 * optabs.c (prepare_float_lib_cmp): Likewise.
11319
36a5eadd
GK
113202002-09-16 Geoffrey Keating <geoffk@apple.com>
11321
11322 * ggc-common.c (ggc_mark_rtx_children_1): Update for changed name
11323 mangling.
11324
11325 The following changes are merged from pch-branch:
11326
11327 * doc/gty.texi (GTY Options): Document %a.
11328 * gengtype.c (do_scalar_typedef): New function.
11329 (process_gc_options): Handle `length' option.
11330 (set_gc_used_type): A pointer to an array of structures doesn't
11331 qualify as a pointer to a structure.
11332 (output_escaped_param): Add `%a' escape.
11333 (write_gc_structure_fields): Allow 'desc' on array of unions.
11334 (main): Define `uint8', `jword' and `JCF_u2' as scalars; use
11335 do_scalar_typedef.
11336
11337 * gengtype.c (enum rtx_code): Make global.
11338 (rtx_format): Make global.
11339 (rtx_next): New.
11340 (gen_rtx_next): New.
11341 (write_rtx_next): New.
11342 (adjust_field_rtx_def): Skip fields marked by chain_next.
11343 (open_base_files): Delete redundant prototype.
11344 (write_enum_defn): New.
11345 (output_mangled_typename): Correct abort call.
11346 (write_gc_marker_routine_for_structure): Handle chain_next and
11347 chain_prev options.
11348 (finish_root_table): Don't output redundant \n.
11349 (main): Call gen_rtx_next, write_rtx_next, write_enum_defn.
11350 * c-tree.h (union lang_tree_node): Add chain_next option.
11351
11352 * gengtype.h (NUM_PARAM): New definition.
11353 (struct type): For TYPE_PARAM_STRUCT, allow multiple parameters.
11354 * gengtype.c (find_param_structure): New.
11355 (adjust_field_type): Handle param<n>_is option.
11356 (process_gc_options): Detect use_params option. Update callers.
11357 (set_gc_used_type): Add 'param' parameter, update callers. Handle
11358 'use_params' option.
11359 (open_base_files): Add splay-tree.h to list of files included.
11360 (output_mangled_typename): New.
11361 (write_gc_structure_fields): Update 'param' parameter to support
11362 multiple parameters. Change name mangling. Allow parameterized
11363 fields to have an apparent scalar type. Handle param<n>_is options,
11364 use_param option.
11365 (write_gc_marker_routine_for_structure): Update for change to name
11366 mangling. Better guess the output file for parameterized types.
11367 (write_gc_types): Update for change to name mangling.
11368 (write_gc_root): Update for change to name mangling. Handle (ignore)
11369 param<n>_is options.
11370 * doc/gty.texi (GTY Options): Add description of param<n>_is
11371 options, use_params option.
11372 * ggc.h (ggc_mark_rtx): Update for changed name mangling.
11373 * gengtype-lex.l: Produce token for param<n>_is.
11374 * gengtype-yacc.y: Parse param<n>_is.
11375
11376 * gengtype.c (adjust_field_tree_exp): Don't name a variable 'rindex'.
11377
11378 * rtl.c: Update comment describing rtx_format.
11379 * rtl.h (union rtunion): Separate definition and typedef.
11380 (struct rtx_def): Use gengtype to mark.
11381 * Makefile.in (gengtype.o): Also depend on rtl.def.
11382 * ggc.h (ggc_mark_rtx_children): Delete prototype.
11383 (ggc_mark_rtx): Change to alias of gengtype-generated routine.
11384 * ggc-common.c (ggc_mark_rtx_children): Delete.
11385 (ggc_mark_rtx_children_1): Delete.
11386 (gt_ggc_m_rtx_def): Delete.
11387 * gengtype.c (adjust_field_rtx_def): New.
11388 (adjust_field_type): Call adjust_field_rtx_def.
11389 (write_gc_structure_fields): Add 'default' case to switch if none
11390 is specified; remove unused code.
11391
11392 * tree.h (struct tree_exp): Update for change to meaning
11393 of special.
11394 * gengtype.c (adjust_field_tree_exp): New function.
11395 (adjust_field_type): Handle `tree_exp' special here.
11396 (write_gc_structure_fields): Don't handle `tree_exp' special here.
11397 Handle new `dot' option.
11398
11399 * gengtype.h: Make `info' a pointer-to-const.
11400 * gengtype-yacc.y (yacc_ids): Use xasprintf.
11401
11402 * gengtype.c (write_gc_structure_fields): Remove implementation
11403 of `always' option, add `default' option.
11404 * doc/gty.texi (GTY Options): Remove documentation of `always',
11405 add `default'.
11406
a7f6d760
HPN
114072002-09-16 Hans-Peter Nilsson <hp@bitrange.com>
11408
11409 * output.h: Remove #ifdef RTX_CODE and #ifdef TREE_CODE.
11410
245ff137
KG
114112002-09-16 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
11412
7c3414b6
KG
11413 * m68hc11.md (addhi_sp): Fix uninitialized variable bug.
11414
245ff137
KG
11415 * c4x-c.c, c4x.c, darwin.c, i370-c.c, m32r.c: Include tm_p.h
11416 instead of the *-protos.h file directly.
11417 * t-c4x, t-i370, t-v850: Depend on $(TM_P_H).
11418 * darwin.c (machopic_output_stub): Move prototype ...
11419 * darwin-protos.h (machopic_output_stub): ... here.
11420 * rs6000-protos.h (machopic_output_stub): Don't declare.
11421
ac520ec9
RH
114222002-09-16 Richard Henderson <rth@redhat.com>
11423
11424 * c-common.c (builtin_define_float_constants): Emit __FOO_DENORM_MIN__.
11425
efdc7e19
RH
114262002-09-16 Richard Henderson <rth@redhat.com>
11427
11428 * real.c, real.h: Rewrite from scratch.
11429
11430 * Makefile.in (simplify-rtx.o): Depend on TREE_H.
11431 (paranoia): New target.
11432 * builtins.c (fold_builtin_inf): Use new real.h interface.
11433 * c-common.c (builtin_define_with_hex_fp_value): Likewise.
11434 * c-lex.c (interpret_float): Likewise.
11435 * emit-rtl.c (gen_lowpart_common): Likewise.
11436 * optabs.c (expand_float): Use real_2expN.
11437 * config/ia64/ia64.md (divsi3, udivsi3): Likewise.
11438 * defaults.h (INTEL_EXTENDED_IEEE_FORMAT): New.
11439 (FLOAT_WORDS_BIG_ENDIAN): New.
11440 * cse.c (find_comparison_args): Don't pass FLOAT_STORE_FLAG_VALUE
11441 directly to REAL_VALUE_NEGATIVE.
11442 * loop.c (canonicalize_condition): Likewise.
11443 * simplify-rtx.c: Include tree.h.
11444 (simplify_unary_operation): Don't handle FIX and UNSIGNED_FIX
11445 with floating-point result modes.
11446 * toplev.c (backend_init): Call init_real_once.
11447
11448 * fold-const.c (force_fit_type): Don't call CHECK_FLOAT_VALUE.
11449 * tree.c (build_real): Likewise.
11450 * config/alpha/alpha.c, config/vax/vax.c (float_strings,
11451 float_values, inited_float_values, check_float_value): Remove.
11452 * config/alpha/alpha.h, config/m68hc11/m68hc11.h,
11453 config/m88k/m88k.h, config/vax/vax.h (CHECK_FLOAT_VALUE): Remove.
11454 * doc/tm.texi (CHECK_FLOAT_VALUE): Remove.
11455 (VAX_HALFWORD_ORDER): Remove.
11456
a41c6c53
UW
114572002-09-16 Ulrich Weigand <uweigand@de.ibm.com>
11458
11459 * config/s390/s390.c: (legitimize_la_operand): Remove, replace by ...
11460 (s390_load_address): ... this new function.
11461 (s390_decompose_address): Allow the argument pointer and all
11462 virtual registers as 'pointer' registers.
11463 (s390_expand_plus_operand): Use s390_load_address.
11464 config/s390/s390.md (movti, movdi, movdf splitters): Likewise.
11465 ("force_la_31"): New insn pattern.
11466 config/s390/s390-protos.h (legitimize_la_operand): Remove.
11467 (s390_load_address): Add prototype.
11468
11469 * config/s390/s390.c: Include "optabs.h".
11470 (s390_expand_movstr, s390_expand_clrstr, s390_expand_cmpstr): New.
b4f94ac1 11471 config/s390/s390-protos.h (s390_expand_movstr, s390_expand_clrstr,
a41c6c53
UW
11472 s390_expand_cmpstr): Add prototypes.
11473 config/s390/s390.md ("movstrdi", "movstrsi"): Call s390_expand_movstr.
11474 ("movstrdi_short"): Rename to "movstr_short_64". Change predicates
11475 for operands 0 and 1 to "memory_operand". Add type attribute.
11476 ("movstrsi_short"): Rename to "movstr_short_31". Change predicates
11477 for operands 0 and 1 to "memory_operand". Add type attribute.
11478 ("movstrdi_long", "movstrsi_long"): Remove.
11479 ("movstrdi_64"): Rename to "movstr_long_64". Add type attribute.
11480 ("movstrsi_31"): Rename to "movstr_long_31". Add type attribute.
11481 ("clrstrdi", "clrstrsi"): Call s390_expand_clrstr.
11482 ("clrstrsico"): Remove, replace by ...
11483 ("clrstr_short_64", "clrstr_short_31"): ... these new patterns.
11484 ("clrstrsi_64"): Rename to "clrstr_long_64".
11485 ("clrstrsi_31"): Rename to "clrstr_long_31".
11486 ("cmpstrdi", "cmpstrsi"): Call s390_expand_cmpstr.
11487 ("cmpstr_const"): Remove, replace by ...
11488 ("cmpstr_short_64", "cmpstr_short_31"): ... these new patterns.
11489 ("cmpstr_64"): Rename to "cmpstr_long_64".
11490 ("cmpstr_31"): Rename to "cmpstr_long_31".
11491
8d9afc4e
KH
114922002-09-16 Kazu Hirata <kazu@cs.umass.edu>
11493
11494 * ABOUT-NLS: Follow spelling conventions.
11495 * ChangeLog: Likewise.
11496 * ChangeLog.1: Likewise.
11497 * ChangeLog.2: Likewise.
11498 * ChangeLog.3: Likewise.
11499 * ChangeLog.4: Likewise.
11500 * ChangeLog.5: Likewise.
11501 * ChangeLog.6: Likewise.
11502 * FSFChangeLog.10: Likewise.
11503 * FSFChangeLog.11: Likewise.
11504 * c-common.c: Likewise.
11505 * c-lex.c: Likewise.
11506 * c-objc-common.c: Likewise.
11507 * cppexp.c: Likewise.
11508 * cppinit.c: Likewise.
11509 * cpplex.c: Likewise.
11510 * doloop.c: Likewise.
11511 * flow.c: Likewise.
11512 * function.c: Likewise.
11513 * integrate.c: Likewise.
11514 * loop.c: Likewise.
11515 * reg-stack.c: Likewise.
11516 * reload.h: Likewise.
11517 * ssa.c: Likewise.
11518
4977bab6
ZW
115192002-09-15 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
11520
11521 * Makefile.in (vmsdbgout.o): Depend on $(TARGET_H)
11522 * vmsdbgout.c: Include "target.h".
11523
981f6289
KH
115242002-09-15 Kazu Hirata <kazu@cs.umass.edu>
11525
11526 * ChangeLog: Follow spelling conventions.
11527 * ChangeLog.0: Likewise.
11528 * ChangeLog.1: Likewise.
11529 * ChangeLog.2: Likewise.
11530 * ChangeLog.4: Likewise.
11531 * ChangeLog.6: Likewise.
11532 * config.gcc: Likewise.
11533 * dwarfout.c: Likewise.
11534 * reload1.c: Likewise.
11535 * simplify-rtx.c: Likewise.
11536 * unwind-sjlj.c: Likewise.
11537 * config/avr/avr.h: Likewise.
11538 * config/d30v/d30v.h: Likewise.
11539 * config/frv/frv.c: Likewise.
11540 * config/frv/frv.h: Likewise.
11541 * config/ip2k/ip2k.h: Likewise.
11542 * config/m88k/m88k-move.sh: Likewise.
11543 * config/stormy16/stormy16.c: Likewise.
11544 * config/stormy16/stormy16.h: Likewise.
11545 * doc/extend.texi: Likewise.
11546 * doc/interface.texi: Likewise.
11547 * doc/invoke.texi: Likewise.
11548 * doc/md.texi: Likewise.
11549 * doc/rtl.texi: Likewise.
11550 * doc/tm.texi: Likewise.
11551 * doc/trouble.texi: Likewise.
11552 * ginclude/float.h: Likewise.
11553 * treelang/treelang.texi: Likewise.
11554
8764eef7
KG
115552002-09-15 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
11556
bb6155b5
KG
11557 * i386-protos.h (i386_pe_dllexport_name_p,
11558 i386_pe_dllimport_name_p, i386_pe_unique_section,
11559 i386_pe_declare_function_type, i386_pe_record_external_function,
11560 i386_pe_record_exported_symbol, i386_pe_asm_file_end): Add
11561 prototype.
11562 * i386/t-cygwin (winnt.o): Depend on $(TM_P_H).
11563 * i386/t-interix (winnt.o): Likewise.
11564
8764eef7
KG
11565 * v850-protos.h (v850_output_addr_const_extra): Prototype.
11566
a24f7c1a
JT
115672002-09-15 Jason Thorpe <thorpej@wasabisystems.com>
11568
11569 * config/mips/netbsd.h (TARGET_OS_CPP_BUILTINS): Add
11570 MIPS ABI CPP macros.
11571 (TARGET_CPU_CPP_BUILTINS): Redefine.
11572 (SUBTARGET_EXTRA_SPECS): Remove subtarget_endian_default.
11573 (SUBTARGET_ENDIAN_DEFAULT_SPEC): Remove.
11574
bd25febf
KG
115752002-09-15 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
11576
11577 * ia64/aix.h (TARGET_OS_CPP_BUILTINS): Fix typo.
11578
05713b80
KH
115792002-09-15 Kazu Hirata <kazu@cs.umass.edu>
11580
11581 * ChangeLog: Follow spelling conventions.
11582 * ChangeLog.0: Likewise.
11583 * ChangeLog.1: Likewise.
11584 * ChangeLog.2: Likewise.
11585 * ChangeLog.3: Likewise.
11586 * ChangeLog.4: Likewise.
11587 * ChangeLog.5: Likewise.
11588 * ChangeLog.6: Likewise.
11589 * FSFChangeLog.10: Likewise.
11590 * FSFChangeLog.11: Likewise.
11591 * c-common.c: Likewise.
11592 * c-common.h: Likewise.
11593 * c-format.c: Likewise.
11594 * c-opts.c: Likewise.
11595 * cpplib.c: Likewise.
11596 * langhooks.h: Likewise.
11597 * real.c: Likewise.
11598 * reg-stack.c: Likewise.
11599 * toplev.c: Likewise.
11600 * config/arm/arm.c: Likewise.
11601 * config/arm/arm.md: Likewise.
11602 * config/arm/linux-gas.h: Likewise.
11603 * config/arm/netbsd.h: Likewise.
11604 * config/c4x/c4x.c: Likewise.
11605 * config/c4x/c4x.h: Likewise.
11606 * config/c4x/c4x.md: Likewise.
11607 * config/c4x/libgcc.S: Likewise.
11608 * config/fr30/fr30.md: Likewise.
11609 * config/frv/frv.md: Likewise.
11610 * config/ia64/ia64.md: Likewise.
11611 * config/mips/mips.h: Likewise.
11612 * config/mn10300/mn10300.c: Likewise.
11613 * config/stormy16/stormy16.c: Likewise.
11614 * config/v850/v850.md: Likewise.
11615 * doc/extend.texi: Likewise.
11616 * doc/invoke.texi: Likewise.
11617 * doc/md.texi: Likewise.
11618
b0c2b2f9
JT
116192002-09-15 Jason Thorpe <thorpej@wasabisystems.com>
11620
11621 * config/netbsd.h (LIB_SPEC): Include the appropriate pthread
11622 library if -pthread is specified.
11623
a0494c05
JT
116242002-09-15 Jason Thorpe <thorpej@wasabisystems.com>
11625
11626 * config.gcc (*-*-netbsd*): Set thread_file to 'posix'
11627 for --enable-threads=yes and --enable-threads=posix.
11628
56149abc
KH
116292002-09-15 Kazu Hirata <kazu@cs.umass.edu>
11630
11631 * config/sparc/cypress.md: Replace Sparc with SPARC.
11632 * config/sparc/freebsd.h: Likewise.
11633 * config/sparc/gmon-sol2.c: Likewise.
11634 * config/sparc/hypersparc.md: Likewise.
11635 * config/sparc/lb1spc.asm: Likewise.
11636 * config/sparc/lb1spl.asm: Likewise.
11637 * config/sparc/linux.h: Likewise.
11638 * config/sparc/linux64.h: Likewise.
11639 * config/sparc/lynx.h: Likewise.
11640 * config/sparc/sol2.h: Likewise.
11641 * config/sparc/sparc-modes.def: Likewise.
11642 * config/sparc/sparc.c: Likewise.
11643 * config/sparc/sparc.h: Likewise.
11644 * config/sparc/sparc.md: Likewise.
11645 * config/sparc/sparclet.md: Likewise.
11646 * config/sparc/supersparc.md: Likewise.
11647 * config/sparc/sysv4.h: Likewise.
11648 * config/sparc/vxsim.h: Likewise.
11649 * config/sparc/vxsparc64.h: Likewise.
11650
4977bab6
ZW
116512002-09-14 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
11652
11653 * c-lex.c (cb_ident): Mark variable with ATTRIBUTE_UNUSED.
11654 * collect2.c (ignore_library, aix_std_libs): Move into the context
11655 where it is used.
11656 * m68hc11.c (m68hc11_autoinc_compatible_p): Delete prototype.
11657 (autoinc_mode, m68hc11_make_autoinc_notes): Add prototypes.
11658 * m88k.c (output_call): Wrap variables with macro controlling use.
11659 * rs6000.md: Likewise. Const-ify variable.
11660 * sh.h (ASM_OUTPUT_LABELREF): Likewise.
11661 * final.c (only_leaf_regs_used): Likewise.
11662 * regrename.c (maybe_mode_change): Mark parameter with
11663 ATTRIBUTE_UNUSED.
11664 * reload.c (find_valid_class): Likewise. Likewise for variable.
11665 (find_reloads_address_1): Likewise.
11666 * varasm.c (weak_finish): Wrap variable with macro controlling use.
11667
3eaf7a3c
MM
116682002-09-14 Marek Michalkiewicz <marekm@amelek.gda.pl>
11669
11670 * config/avr/avr.c (output.h): Move after inclusion of tree.h.
11671
4912a07c
KH
116722002-09-14 Kazu Hirata <kazu@cs.umass.edu>
11673
11674 * ChangeLog: Follow spelling conventions.
11675 * ChangeLog.0: Likewise.
11676 * ChangeLog.2: Likewise.
11677 * ChangeLog.3: Likewise.
11678 * ChangeLog.4: Likewise.
11679 * ChangeLog.5: Likewise.
11680 * ChangeLog.6: Likewise.
11681 * cppfiles.c: Likewise.
11682 * cppinit.c: Likewise.
11683 * cpplib.h: Likewise.
11684 * cse.c: Likewise.
11685 * debug.h: Likewise.
11686 * df.c: Likewise.
11687 * dominance.c: Likewise.
11688 * hashtable.c: Likewise.
11689 * hashtable.h: Likewise.
11690 * loop.c: Likewise.
11691 * config/arm/README-interworking: Likewise.
11692 * config/arm/arm.c: Likewise.
11693 * config/arm/arm.h: Likewise.
11694 * config/arm/arm.md: Likewise.
11695 * config/dsp16xx/dsp16xx.h: Likewise.
11696 * config/frv/frv.c: Likewise.
11697 * config/frv/frv.h: Likewise.
11698 * config/ip2k/ip2k.h: Likewise.
11699 * config/rs6000/rs6000.c: Likewise.
11700 * config/stormy16/stormy-abi: Likewise.
11701 * config/stormy16/stormy16.h: Likewise.
11702 * config/v850/v850.c: Likewise.
11703
3dc60fc7
KH
117042002-09-14 Kazu Hirata <kazu@cs.umass.edu>
11705
11706 * loop.c: Fix a comment typo.
11707
a920aefe
KH
117082002-09-14 Kazu Hirata <kazu@cs.umass.edu>
11709
11710 * config/fr30/fr30.h: Fix comment typos.
11711 * config/frv/frv.c: Likewise.
11712 * config/i386/xmmintrin.h: Likewise.
11713 * config/mips/mips.c: Likewise.
11714 * config/sh/sh.c: Likewise.
11715
88cad84b
KH
117162002-09-14 Kazu Hirata <kazu@cs.umass.edu>
11717
11718 * haifa-sched.c: Follow spelling conventions.
11719 * regclass.c: Likewise.
11720 * regrename.c: Likewise.
11721 * config/fp-bit.c: Likewise.
11722 * config/frv/frv.h: Likewise.
11723 * config/m88k/m88k.c: Likewise.
11724 * config/mcore/mcore.c: Likewise.
11725 * config/rs6000/darwin.h: Likewise.
11726 * config/rs6000/gnu.h: Likewise.
11727 * config/rs6000/linux.h: Likewise.
11728 * config/rs6000/linux64.h: Likewise.
11729 * config/rs6000/rs6000.c: Likewise.
11730 * config/rs6000/rs6000.h: Likewise.
11731 * config/sh/sh.c: Likewise.
11732 * config/sparc/sparc.c: Likewise.
11733 * config/sparc/ultra1_2.md: Likewise.
11734
f197f1cf
SC
117352002-09-14 Stephane Carrez <stcarrez@nerim.fr>
11736
11737 * config/m68hc11/m68hc11.md ("movdi_internal"): Allow any offsetable
11738 memory operand when source is 0 (K constraint).
11739 ("movsi_internal"): Likewise.
11740 ("movdf_internal"): Likewise.
11741 ("movsf_internal"): Likewise.
11742
b629ba0c
AM
117432002-09-14 Alan Modra <amodra@bigpond.net.au>
11744
11745 * config/rs6000/rs6000.c (rs6000_elf_encode_section_info): Use
11746 targetm.binds_local_p to set SYMBOL_REF_FLAG.
11747 (rs6000_xcoff_encode_section_info): Likewise.
11748 * config/rs6000/xcoff.h (ASM_DECLARE_FUNCTION_NAME): Likewise.
11749
2e485129
TR
117502002-09-10 Theodore A. Roth <troth@verinet.com>
11751
11752 * gcc/config/avr/avr.h: Set default options for C++ for avr.
11753
4977bab6
ZW
117542002-09-13 Roger Sayle <roger@eyesopen.com>
11755
11756 * stmt.c (struct nexting): Remove unused alt_end_label field.
11757 (expand_start_loop): Delete initialization of alt_end_label.
11758 (expand_start_null_loop): Likewise.
11759 (expand_exit_loop_if_false): Delete updating of alt_end_label.
11760
907aee69
RH
117612002-09-13 Richard Henderson <rth@redhat.com>
11762
11763 * Makefile.in (toplev.o): Depend on real.h.
11764 (print-rtl.o, varasm.o, ifcvt.o): Likewise.
11765
374b0b7d
AM
117662002-09-14 Alan Modra <amodra@bigpond.net.au>
11767
11768 * doc/tm.texi (DBX_OUTPUT_NFUN): Describe.
11769 * dbxout.c (dbxout_function_end): Use DBX_OUTPUT_NFUN.
11770 * config/rs6000/linux64.h (DBX_OUTPUT_NFUN): Define.
11771
690eed2c
NS
117722002-09-13 Nathan Sidwell <nathan@codesourcery.com>
11773
11774 * ggc-common.c (ggc_mark_roots): Don't iterate NULL hash tables.
11775
32b4f6f4
SE
117762002-09-13 Steve Ellcey <sje@cup.hp.com>
11777
11778 * config.gcc (ia64*-*-aix*, ia64*-*-elf*, ia64*-*-freebsd*,
11779 ia64*-*-linux*): Set extra_parts.
11780 * config/ia64/t-aix (EXTRA_PARTS): Remove.
11781 * config/ia64/t-ia64 (EXTRA_PARTS): Remove.
11782
3db11b5c
KH
117832002-09-13 Kazu Hirata <kazu@cs.umass.edu>
11784
11785 * config/h8300/fixunssfsi.c: Replace H8/S with H8S.
11786 * config/h8300/h8300.c: Likewise.
11787 * config/h8300/h8300.h: Likewise.
11788 * config/h8300/h8300.md: Likewise.
11789 * doc/invoke.texi: Likewise.
11790
b6894857
KH
117912002-09-13 Kazu Hirata <kazu@cs.umass.edu>
11792
11793 * config/h8300/h8300.c (h8300_init_once): Fix formatting.
11794
d5909a79
RH
117952002-09-13 Richard Henderson <rth@redhat.com>
11796
11797 * config/alpha/alpha.md (attr type): Add callpal.
11798 (imb, trap, load_tp, set_tp): Use it.
11799 * config/alpha/ev4.md (ev4_callpal): New.
11800 * config/alpha/ev5.md (ev5_callpal): New.
11801 * config/alpha/ev6.md (ev6_ibr): Handle callpal.
11802 * config/alpha/alpha.c (alphaev4_insn_pipe): Handle TYPE_CALLPAL.
11803 (alphaev5_insn_pipe): Likewise.
11804
e0073fa8
AJ
118052002-09-13 Andreas Jaeger <aj@suse.de>
11806
11807 * Makefile.in (print-rtl.o): Depend on CONFIG_H.
11808
1f298625
SE
118092002-09-13 Steve Ellcey <sje@cup.hp.com>
11810
11811 * config/ia64/t-hpux (LIBGCC1_TEST, STMP_FIXPROTO,
11812 LIB2ADDEH): New, set to NULL.
11813 (SHLIB_EXT, SHLIB_LINK, SHLIB_INSTALL, SHLIB_MKMAP): New.
11814
1a7e1470
SE
118152002-09-13 Steve Ellcey <sje@cup.hp.com>
11816
11817 * config/ia64/quadlib.c (_U_Qfcmp): Make extern.
11818 (_U_Qfcnvfxt_quad_to_sgl): Remove declaration.
11819 (_U_Qfeq, _U_Qfne, _U_Qfgt, _U_Qfge, U_Qflt, U_Qfle, _U_Qfcomp):
11820 Add declarations.
11821 (_U_Qfneg): Remove.
11822
d56c04ce
DD
118232002-09-13 Dhananjay Deshpande <dhananjayd@kpit.com>
11824
11825 * config/h8300/h8300.h (EIGHTBIT_CONSTANT_ADDRESS_P): Add support
8d9afc4e
KH
11826 for H8/300, H8S aa:8 mode.
11827 (TINY_CONSTANT_ADDRESS_P): Add support for H8S aa:16 mode.
d56c04ce
DD
11828 * config/h8300/h8300.c (h8300_adjust_insn_length): Adjust length
11829 for H8/300 aa:8 mode.
11830
4456530d
HP
118312002-09-13 Hartmut Penner <hpenner@de.ibm.com>
11832
11833 * config/s390/s390.md ("trap", "conditional_trap", "*trap"): New
11834 insns.
11835
4d2d910c
RH
118362002-09-12 Richard Henderson <rth@redhat.com>
11837
11838 * Makefile.in (HOST_PRINT): Use print-rtl1.o
11839 (print-rtl.o): Don't define GENERATOR_FILE.
11840 (print-rtl1.o): Rename from $(BUILD_PREFIX_1)print-rtl.o.
11841 * print-rtl.c (print_rtx): Include CONST_DOUBLE fp decimal output
11842 unless GENERATOR_FILE.
11843
7606e68f
SS
118442002-09-12 Stan Shebs <shebs@apple.com>
11845
6ab9a3f4
SS
11846 * config/darwin.h (USER_LABEL_PREFIX): Define here...
11847 * config/i386/darwin.h: ... instead of here.
11848
7606e68f
SS
11849 * target.h (struct gcc_target): New field
11850 terminate_dw2_eh_frame_info.
11851 * target-def.h (TARGET_TERMINATE_DW2_EH_FRAME_INFO): Define.
11852 (TARGET_INITIALIZER): Add it.
11853 * dwarf2out.c (output_call_frame_info): Use target hook.
11854 * dwarf2asm.c (dw2_asm_output_delta): Use macro
11855 ASM_OUTPUT_DWARF_DELTA if defined.
11856 * doc/tm.texi (TARGET_TERMINATE_DW2_EH_FRAME_INFO): Document.
11857 (ASM_OUTPUT_DWARF_DELTA): Ditto.
11858 (ASM_OUTPUT_DWARF_OFFSET): Ditto.
11859 (ASM_OUTPUT_DWARF_PCREL): Ditto.
11860 * config.gcc (i[34567]86-*-darwin*): Define extra_parts.
11861 (powerpc-*-darwin*): Ditto.
11862 * crtstuff.c [OBJECT_FORMAT_MACHO]: Update the Mach-O bits
11863 to work correctly for Darwin.
11864 * config/darwin.h (OBJECT_FORMAT_MACHO): Define.
11865 (STARTFILE_SPEC): Add crtbegin.o.
11866 (ENDFILE_SPEC): Define.
11867 (EXTRA_SECTION_FUNCTIONS): Put gcc_except_tab in data segment.
11868 (ASM_PREFERRED_EH_DATA_FORMAT): Handle more cases.
11869 (ASM_OUTPUT_DWARF_DELTA): Define.
11870 (TARGET_TERMINATE_DW2_EH_FRAME_INFO): Define.
11871 * config/darwin.c (darwin_asm_output_dwarf_delta): New function.
11872
20b71b17
AM
118732002-09-13 Alan Modra <amodra@bigpond.net.au>
11874
11875 * config/rs6000/rs6000.c (rs6000_emit_load_toc_table): Remove "if"
11876 nesting. Correct test for non-PowerPC64 ELF ABI_AIX.
11877 * config/rs6000/rs6000.md (load_toc_v4_PIC*): Disable when ABI_AIX.
11878
d48fd218
ZW
118792002-09-12 Zack Weinberg <zack@codesourcery.com>
11880
11881 * toplev.c: Move default definition of USER_LABEL_PREFIX...
11882 * defaults.h: ... here.
11883
92bc3c1a
RH
118842002-09-12 Richard Henderson <rth@redhat.com>
11885
11886 * vax.c: Include tree.h earlier.
11887
3f64e543
SS
118882002-09-12 Stan Shebs <shebs@apple.com>
11889
11890 * config/darwin.c (machopic_finish): Remove #if 0 chunks.
11891 (machopic_operand_p): Ditto.
11892
52bd31bb
KH
118932002-09-12 Kazu Hirata <kazu@cs.umass.edu>
11894
11895 * config/arm/arm.c (arm_compute_initial_elimination_offset):
11896 Fix a comment typo.
11897
387c9294
KH
118982002-09-12 Kazu Hirata <kazu@cs.umass.edu>
11899
11900 * toplev.c (do_abort): Fix a comment typo.
11901
e34bb004
KH
119022002-09-12 Kazu Hirata <kazu@cs.umass.edu>
11903
11904 * cselib.c: Fix comment formatting.
11905 * gengtype.c: Likewise.
11906
d0029ebd
KH
119072002-09-12 Kazu Hirata <kazu@cs.umass.edu>
11908
11909 * config/h8300/h8300.md (udivmodqi4): Do not use an expander.
11910 (udivmodhi4): Likewise.
11911
c3c637e3 119122002-09-12 Graham Stott <graham.stott@btinternet.com>
d48fd218 11913 Roger Sayle <roger@eyesopen.com>
c3c637e3
GS
11914
11915 * i386.c (any_fp_register_operand, fp_register_operand,
11916 register_and_not_any_fp_reg_operand, register_and_not_fp_reg_operand):
11917 New predicate functions.
11918 * i386-protos.h: Add their prototypes.
11919 * i386.h: Add them to PREDICATE_CODES.
11920 * i386.md ("*pushsf_rex64"+2, "*pushsf_rex64"+3, "*pushdf_integer"+1,
11921 "*pushdf_integer"+2, "*pushtf_integer"+1, "*pushtf_integer"+2,
11922 "*pushtf_integer"+3, "*pushtf_integer"+4, "*dummy_extendsfdf2"+1,
11923 "*dummy_extendsfdf2"+2, "*dummy_extendsfxf2"+1,
11924 "*dummy_extendsftf2"+1, "*dummy_extendsftf2"+2,
11925 "*dummy_extenddfxf2"+1, "*dummy_extenddftf2"+1,
11926 "*dummy_extenddftf2"+2, "*negsf2_if"+1, "*negsf2_if"+2,
11927 "*negdf2_if_rex64"+1, "*negdf2_if_rex64"+2, "*negxf2_if"+1,
11928 "*negxf2_if"+2, "*negtf2_if"+1, "*negtf2_if"+2, "*abssf2_if"+1,
11929 "*abssf2_if"+2, "*absdf2_if_rex64"+1, "*absdf2_if_rex64"+2,
11930 "*absxf2_if"+1, "*absxf2_if"+2, "*abstf2_if"+1, "*abstf2_if"+2):
11931 Use these new predicates to simplify and correct the use of
11932 FP_REG_P, ANY_FP_REG_P, FP_REGNO_P and any ANY_FP_REGNO_P.
11933
db4c55f6
JM
119342002-09-12 Jason Merrill <jason@redhat.com>
11935
236a2ac8
JM
11936 * diagnostic.c (output_add_identifier): New fn.
11937 * diagnostic.h: Declare it.
11938
db4c55f6
JM
11939 * calls.c (store_one_arg): Use size_in_bytes to determine the
11940 amount of space to push.
11941
13c0bc20
JJ
119422002-09-12 Jakub Jelinek <jakub@redhat.com>
11943
11944 * config/sparc/linux64.h (STARTFILE_SPEC32): Fix a typo.
11945
0a3bdf9d
UW
119462002-09-12 Ulrich Weigand <uweigand@de.ibm.com>
11947
11948 * config/s390/s390-modes.def (CCAPmode, CCANmode): New CC modes.
11949 * config/s390/s390.c (s390_match_ccmode_set): Support new CC modes.
11950 (s390_select_ccmode): Likewise.
11951 (s390_branch_condition_mask): Likewise.
11952 (optimization_options): Do not set flag_branch_on_count.
11953 (s390_split_branches): Handle doloop branches.
11954 (s390_chunkify_pool): Likewise.
11955 * config/s390/s390.md ("*adddi3_imm_cc", "*addsi3_imm_cc"): New insns.
11956 ("doloop_end"): New expander.
11957 ("doolop_si", "*doloop_si_long", "doloop_di", "*doloop_di_long",
11958 associated splitters): New.
11959
4977bab6
ZW
119602002-09-11 Volker Reichelt <reichelt@igpm.rwth-aachen.de>
11961
11962 * genattrtab.c (simplify_cond): Remove unused variable(s).
11963 * global.c (record_conflicts): Likewise.
11964 * jump.c (rebuild_jump_labels): Likewise.
11965 * loop.c (scan_loop, check_final_value): Likewise.
11966 * ra-colorize.c (colorize_one_web, assign_colors): Likewise.
11967 * reload1.c (eliminate_regs_in_insn, do_input_reload): Likewise.
11968 * rtlanal.c (reg_set_p): Likewise.
11969 * stmt.c (expand_asm_operands, expand_decl): Likewise.
11970 * genautomata.c (empty_reserv): Remove.
11971 * loop.c (max_luid): Likewise.
11972 * sched-rgn.c (bitlst_table_size): Likewise.
11973
119742002-09-11 Nathan Sidwell <nathan@codesourcery.com>
11975
11976 Reimplement gcov format.
11977 * gcov-io.h: Replace.
11978 * gcov.c: Reimplement.
11979 * gcov-iov.c: New file.
11980 * gcov-dump.c: New file.
11981 * libgcc2.c (L_bb): Replace with ...
11982 (L_gcov): ... this.
11983 (struct bb_function_info, struct bb): Remove.
11984 (inhibit_libc): Never inhibit.
11985 (gcov_list, gcov_crc): New static variables.
11986 (gcov_version_mismatch): New static function.
11987 (__bb_exit_func): Renamed to ...
11988 (__gcov_exit): ... here. Made static. Reimplement.
11989 (__gcov_init_func): Rename to ...
11990 (__gcov_init): ... here. Check version, update crc.
11991 (__bb_fork_func): Rename to ...
11992 (__gcov_flush): ... here.
11993 * libgcc2.h (struct bb, __bb_exit_func, __bb_init_func,
11994 __bb_fork_func, gcov_type, __bb_find_arc_counters): Remove.
11995 * calls.c (expand_call): Call __gcov_flush.
11996 * profile.c (bb_file, last_bb_file_name): Remove.
11997 (bbg_file_name): New global variable.
11998 (output_gcov_string): Remove.
11999 (get_exec_counts): Reimplement.
12000 (branch_prob): Reimplement gcov file writing.
12001 (init_branch_prob): Create bbg_file_name, don't create
12002 bb_file_name.
12003 (end_branch_prob): Adjust. Don't remove counter file when
12004 instrumenting ourselves.
12005 (create_profiler): Adjust.
12006 * doc/gcov.texi (Gcov Data Files): Remove detailed specification,
12007 point to gcov-io.h.
12008 * Makefile.in (LANGUAGES): Add gcov-dump.
12009 (coverageexts): Remove .bb.
12010 (STAGESTUFF): Add gcov-dump.
12011 (LIB2FUNCS_ST): Replace _bb with _gcov.
12012 (profile.o): Depend on gcov-iov.h.
12013 (final.o): Don't depend on profile.h, gcov.h.
12014 (gcov.o): Depend on gcov-iov.h.
12015 (gcov-iov.o): New target.
12016 (gcov-iov): New target.
12017 (gcov-iov.h): New target.
12018 (gcov-dump.o): New target.
12019 (GCOV_DUMP_OBJS): New variable.
12020 (gcov-dump): New target.
12021 (distclean): Remove coverageexts.
12022 (stage1): Remove coverageexts.
12023
4f968d93
HP
120242002-09-11 Hartmut Penner <hpenner@de.ibm.com>
12025
12026 * fold-const.c (make_range): Only narrow to signed range if
12027 the signed range is smaller than the unsigned range.
12028
35aff10b
AM
120292002-09-12 Alan Modra <amodra@bigpond.net.au>
12030
12031 * emit-rtl.c (set_mem_size): New function.
12032 * expr.h (set_mem_size): Declare.
12033 * config/rs6000/rs6000.c (expand_block_move_mem): Exterminate.
12034 (expand_block_move): Instead, use adjust_address and
12035 replace_equiv_address to generate proper aliasing info.
12036 Move common code out of conditionals. Localize vars.
12037
a9b6f1e7 120382002-09-11 Eric Botcazou <ebotcazou@libertysurf.fr>
d48fd218 12039
874f6a6d
EB
12040 * optabs.c (expand_binop): Minor cleanup.
12041 (expand_twoval_binop): Convert CONST_INTs like in expand_binop.
12042
d1df930b
DN
120432002-09-11 Dan Nicolaescu <dann@ics.uci.edu>
12044
12045 * print-tree.c (print_node): Print the restrict qualifier.
12046
9026a957
JJ
120472002-09-11 Janis Johnson <janis187@us.ibm.com>
12048
12049 * doc/install.texi: Fix typos.
12050
3fd9d606
ZW
120512002-09-11 Zack Weinberg <zack@codesourcery.com>
12052
12053 * Makefile.in: Remove all references to s-under and underscore.c.
12054 * collect2.c, tlink.c: Change all uses of prepends_underscore
12055 to look directly at USER_LABEL_PREFIX.
12056
5b5198f7
DE
120572002-09-11 David Edelsohn <edelsohn@gnu.org>
12058
12059 * config/rs6000/rs6000.c (rs6000_xcoff_asm_named_section): Append
12060 alignment to csect.
12061 (rs6000_xcoff_unique_section): Only set section name for public
12062 data.
12063 (rs6000_xcoff_section_type_flags): Store log2 alignment in flags.
12064 * config/rs6000/xcoff.h (TARGET_ASM_SELECT_SECTION): Remove
12065 duplicate definition.
12066
77de9af2
JDA
120672002-09-10 John David Anglin <dave@hiauly1.hia.nrc.ca>
12068
12069 * pa.md (extzv): Check predicates before emitting extzv_32.
12070 (insv): Likewise.
12071
33b679d1
UW
120722002-09-10 Ulrich Weigand <uweigand@de.ibm.com>
12073
12074 * config/s390/s390.h (MOVE_MAX): Define to correct value.
12075 (MAX_MOVE_MAX): Define.
12076 (MOVE_BY_PIECES_P): Define.
12077 (CLEAR_BY_PIECES_P): Define.
12078
bfae8040
DC
120792002-09-10 Denis Chertykov <denisc@overta.ru>
12080
12081 * config/avr/avr.md (movstrhi): Use right operands for conversion.
12082
7730c3ff
RE
120832002-09-10 Richard Earnshaw <rearnsha@arm.com>
12084
12085 PR c/7873
12086 * arm.md (insv): Use reg_or_int_operand for operand[3].
12087
5add3202
DE
120882002-09-10 David Edelsohn <edelsohn@gnu.org>
12089
12090 * rs6000.c (rs6000_assemble_visibility): Protect declaration
12091 inside macro. Correct function definition typo.
12092 (rs6000_xcoff_section_type_flags): New function.
12093 (TARGET_SECTION_TYPE_FLAGS): Remove definition.
12094 (rs6000_elf_section_type_flags): Call default_section_type_flags_1
12095 with appropriate PIC test.
12096 (rs6000_xcoff_select_section): Use decl_readonly_section_1 to
12097 determine readonly.
12098 (rs6000_binds_local_p): Combine PIC flags.
12099 * sysv4.h (TARGET_SECTION_TYPE_FLAGS): Define.
12100 * xcoff.h (TARGET_SECTION_TYPE_FLAGS): Define.
12101
4977bab6
ZW
121022002-09-09 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
12103
12104 * h8300.md: Fix signed/unsigned warnings.
12105 * mcore.md: Likewise.
12106 * mn10300.c (mask_ok_for_mem_btst): Likewise.
12107
90389422
PB
121082002-09-09 Per Bothner <per@bothner.com>
12109
12110 * print-tree.c (print_node): In a STRING_CST, escape non-ascii
12111 characters, and only print TREE_STRING_LENGTH chars.
12112
686f3bf0
SE
121132002-09-09 Steve Ellcey <sje@cup.hp.com>
12114
12115 * config/ia64/hpux.h (TARGET_HPUX_LD): New, define true.
12116 (ASM_FILE_END) New.
12117 * config/ia64/ia64.h (TARGET_HPUX_LD): New, define false.
12118 * config/ia64/ia64-protos.h (ia64_hpux_asm_file_end): New.
12119 * config/ia64/ia64.c (ia64_asm_output_external): Create list
12120 of external functions if TARGET_HPUX_LD is true.
12121 (ia64_hpux_add_extern_decl): New, routine to put names on
12122 list of external functions.
12123 (ia64_hpux_asm_file_end): Put out declarations for external
12124 functions if and only if they are used.
12125
0c263f4e
JDA
121262002-09-09 John David Anglin <dave@hiauly1.hia.nrc.ca>
12127
12128 * pa.md (exception_receiver, builtin_setjmp_receiver): Add blockage
12129 on TARGET_64BIT before pic register restore.
12130
e2a6476e
DE
121312002-09-09 David Edelsohn <edelsohn@gnu.org>
12132
12133 * doc/tm.texi (TARGET_HAVE_SRODATA_SECTION): New description.
12134 (TARGET_HAVE_TLS): New description.
12135
b73b1546
JJ
121362002-09-09 Janis Johnson <janis187@us.ibm.com>
12137
12138 * doc/extend.texi (Statement Exprs): Fix broken link.
12139
a9738643
DC
121402002-09-09 Denis Chertykov <denisc@overta.ru>
12141
12142 * config/avr/avr.md (movstrhi, clrstrhi): Use gen_int_mode for
12143 right conversion of operands[1].
12144
05b9aaaa
UW
121452002-09-09 Ulrich Weigand <uweigand@de.ibm.com>
12146
12147 * config/s390/s390.md ("*tmdi_reg", "*tmsi_reg"): Do not mark as
12148 commutative. Use "nonimmediate_operand" instead of "register_operand"
12149 as predicate for operand 0. Move to after the "*tmXX_mem" insns.
12150
12151 ("*tmdi_mem", "*tmsi_mem", "*tmhi_mem", "*tmqi_mem"): Do not mark
12152 as commutative.
12153
12154 ("*anddi3_ni", "*andsi3_ni", "*iordi3_ni", "*iorsi3_ni"): Do not
12155 mark as commutative. Use "nonimmediate_operand" instead of
12156 "register_operand" as predicate for operand 1.
12157
12158 ("movstrictsi"): Fix typo in insn name.
12159
7ec70495
JH
121602002-09-09 Jan Hubicka <jh@suse.cz>
12161
12162 * i386.c (index_register_operand): New.
12163 * i386.h (predicate_codes): Add new predicate.
8e746279 12164 * i386.md (lea_general_*): Use index_register_operand
7ec70495
JH
12165 (ashift to lea splitter): Do not produce invalid leas
12166 (ashift to mov+ashift split): New.
12167
b2fc915b
NC
121682002-09-09 Nick Clifton <nickc@redhat.com>
12169
12170 * config/fr30/fr30.c (output.h): Move after inclusion of tree.h.
12171 Fix folding marks.
12172
0b0ad147 121732002-09-09 Toshiyasu Morita <toshiyasu.morita@hsa.hitachi.com>
d48fd218 12174 J"orn Rennecke <joern.rennecke@superh.com>
0b0ad147
TM
12175
12176 * sh/sh.h (OVERRIDE_OPTIONS): align_functions is in bytes, not bits.
12177
2bcc50d0
AM
121782002-09-09 Alan Modra <amodra@bigpond.net.au>
12179
12180 * config/rs6000/rs6000.c (rs6000_binds_local_p): Return bool.
12181 (function_ok_for_sibcall): Use binds_local_p. Respect longcall
12182 attributes.
12183
4977bab6
ZW
121842002-09-08 Nathan Sidwell <nathan@codesourcery.com>
12185
12186 * basic_block.h (gcov_type): Explain why it is signed.
12187 * final.c: Don't include profile.h.
12188 (struct function_list, functions_head, functions_tail,
12189 end_final): Moved to profile.c
12190 (final): Move arc chaining code to profile.c.
12191 * function.c (prepare_function_start): Remove duplicate line.
12192 * output.h (end_final): Remove prototype.
12193 * predict.c (estimate_loops_at_level): Use gcov_type.
12194 * profile.c (struct function_list, functions_head,
12195 functions_tail): Moved from final.c
12196 (need_func_profiler): Remove.
12197 (instrument_edges): Don't set need_func_profiler.
12198 (get_exec_counts): Avoid signed/unsigned warning.
12199 (compute_checksum): Use crc32.
12200 (branch_prob): Adjust. Chain onto functions_head.
12201 (init_branch_prob): Absorb init_edge_profiler.
12202 (init_edge_profiler): Remove.
12203 (create_profiler): Moved and renamed from final.c:end_final.
12204 Emit data and constructor.
12205 (output_func_start_profiler): Remove.
12206 * profile.h (struct profile_info): checksum is unsigned.
12207 * rtl.h (output_func_start_profiler): Remove prototype.
12208 (create_profiler): Declare.
12209 * toplev.c (compile_file): Call create_profiler, if instrumenting
12210 arcs. Don't call end_final.
12211
c1b4f089
KG
122122002-09-08 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
12213
12214 * fr30.c (fr30_print_operand): Fix bug in output of CONST_DOUBLE.
12215
b9203463
RH
122162002-09-08 Richard Henderson <rth@redhat.com>
12217
12218 * dwarf2.h (DW_OP_call_ref): Rename from DW_OP_calli.
12219 (DW_OP_GNU_push_tls_address): New.
12220 (DW_OP_lo_user): Fix.
12221 * dwarf2out.c (INTERNAL_DW_OP_tls_addr): New.
12222 (dwarf_stack_op_name): Handle it, plus other dwarf3 opcodes.
12223 (size_of_loc_descr): Likewise.
12224 (output_loc_operands): Handle INTERNAL_DW_OP_tls_addr.
12225 (add_AT_location_description): Take a dw_loc_descr_ref not an rtx.
12226 (loc_descriptor_from_tree): Handle TLS variables.
12227 (rtl_for_decl_location): Do avoid_constant_pool_reference here ...
12228 (add_location_or_const_value_attribute): ... not here. Defer
12229 to loc_descriptor_from_tree for TLS variables.
12230
12231 * config/i386/i386.h (ASM_OUTPUT_DWARF_DTPREL): New.
12232 * config/i386/i386.c (i386_output_dwarf_dtprel): New.
12233 * config/i386/i386-protos.h: Update.
12234
7df98878
RS
122352002-09-08 Roger Sayle <roger@eyesopen.com>
12236
12237 PR optimization/6405
12238 * unroll.c (loop_iterations): last_loop_insn should be the previous
12239 non-note instruction before loop->end.
12240 * loop.c (strength_reduce): The conditional jump is the last
12241 non-note instruction before loop->end (as above).
12242
f40f4c8e
RS
122432002-09-08 Roger Sayle <roger@eyesopen.com>
12244
12245 * combine.c (try_combine): Handle the case that undobuf.other_insn
12246 has been turned into a return or unconditional jump, by inserting
12247 a BARRIER if necessary.
12248 (simplify_set): Test if a condition code setter has a constant
12249 comparison at compile time, if so convert this insn to a no-op move
12250 and update/simplify the condition code user (undobuf.other_insn).
12251
e2f97e26
KW
122522002-09-08 Krister Walfridsson <cato@df.lth.se>
12253
12254 * config/arm/netbsd.h (INITIALIZE_TRAMPOLINE): Redefine.
12255 (CLEAR_INSN_CACHE): Define.
12256
4b7e68e7
KH
122572002-09-08 Kazu Hirata <kazu@cs.umass.edu>
12258
12259 * basic-block.h: Fix comment formatting.
12260 * c-common.c: Likewise.
12261 * c-common.h: Likewise.
12262 * c-lex.c: Likewise.
12263 * c-pretty-print.c: Likewise.
12264 * cfglayout.c: Likewise.
12265 * cfgloop.c: Likewise.
12266 * defaults.h: Likewise.
12267 * et-forest.c: Likewise.
12268 * explow.c: Likewise.
12269 * function.h: Likewise.
12270 * gcov.c: Likewise.
12271 * genattrtab.c: Likewise.
12272 * gengtype.c: Likewise.
12273 * ifcvt.c: Likewise.
12274 * libgcc2.c: Likewise.
12275 * loop.c: Likewise.
12276 * profile.c: Likewise.
12277 * ra-build.c: Likewise.
12278 * real.c: Likewise.
12279 * rtl.h: Likewise.
12280 * tracer.c: Likewise.
12281 * tree-inline.c: Likewise.
12282 * varasm.c: Likewise.
12283
2567406a
JH
122842002-09-08 Jan Hubicka <jh@suse.cz>
12285
12286 * emit-rtl.c (set_mem_attributes_minus_bitpos): Fix array_ref
12287 handling.
12288
a36fc5f8 12289 * loop.c (loop_givs_reduce): Emit addition after.
2567406a 12290
bd79540a
AM
122912002-09-08 Alan Modra <amodra@bigpond.net.au>
12292
12293 * varasm.c (default_assemble_visibility): Rename from
12294 assemble_visibility.
12295 * output.h: Here too.
12296 * target-def.h (TARGET_ASM_ASSEMBLE_VISIBILITY): And here.
12297 * config/rs6000/rs6000.c (rs6000_assemble_visibility): And here.
12298
32ff9c74
AM
122992002-09-08 Alan Modra <amodra@bigpond.net.au>
12300
12301 * reload.c (find_reloads <p constraint>): Pass operand_mode to
12302 find_reloads_address.
12303
6588987e
KH
123042002-09-08 Kazu Hirata <kazu@cs.umass.edu>
12305
12306 * config/h8300/h8300.md (udivmodqi4): Enable on H8/300.
12307 (anonymous pattern): Likewise.
12308
4977bab6
ZW
123092002-09-07 Igor Shevlyakov <igor@microunity.com>
12310
12311 * machmode.def: Add modes for half-float vectors.
12312
0100732e
SS
123132002-09-07 Scott Snyder <snyder@fnal.gov>
12314
12315 PR target/7374
12316 * config/alpha/alpha.md (abstf2): Fix typo: 'neg' for 'abs'.
12317
77043c7c
RS
123182002-09-07 Roger Sayle <roger@eyesopen.com>
12319
12320 * basic-block.h (struct loop): Remove unused cont_dominator field.
12321
5dd78220
IS
123222002-09-07 Igor Shevlyakov <igor@microunity.com>
12323
d48fd218 12324 * varasm.c (decode_rtx_const): Don't check undefined field for
5dd78220
IS
12325 CONST_VECTOR.
12326
b96a3fa3
GN
123272002-09-07 Glen Nakamura <glen@imodulo.com>
12328
7fa86a10 12329 PR opt/7814
b96a3fa3
GN
12330 * sched-deps.c (sched_analyze_insn): Make sure to add insn
12331 to reg_last->sets after flushing the dependency lists to guarantee
12332 that subsequent clobbers will be dependent on it.
12333
ad9df12f 123342002-09-07 Igor Shevlyakov <igor@microunity.com>
2567406a 12335
ad9df12f
IS
12336 * combine.c (simplify_shift_const): Calculate rotate count
12337 correctly for vector operands.
12338
54c93c30
AE
123392002-09-07 Ansgar Esztermann <ansgar@thphy.uni-duesseldorf.de>
12340
12341 * c-typeck.c (c_tree_expr_nonnegative_p): New function.
12342 (build_binary_op): Call c_tree_expr_nonnegative_p rather than
2567406a 12343 tree_expr_nonnegative_p.
54c93c30
AE
12344 (build_conditional_expr): Likewise.
12345 * c-tree.h (c_tree_expr_nonnegative_p): Declare.
12346
36eea25f
RH
123472002-09-07 Richard Henderson <rth@redhat.com>
12348
3aa4cad7
RH
12349 * builtins.def (inf, inff, infl): Mark const.
12350 (huge_val, huge_valf, huge_vall): Likewise.
12351 (BUILT_IN_GETEXP, BUILT_IN_GETMAN): Remove.
12352
36eea25f
RH
12353 * real.c (ereal_inf): Clear E before use.
12354
5c102b48
KH
123552002-09-07 Kazu Hirata <kazu@cs.umass.edu>
12356
12357 * config/h8300/h8300.md (udivmodqi4): Split the pattern into
12358 an expander and an anonymous pattern. Zero out the upper half
12359 of the dividend in the expander.
12360 (udivmodqi4): Likewise.
12361
8bd06267
KH
123622002-09-07 Kazu Hirata <kazu@cs.umass.edu>
12363
12364 * config/h8300/h8300.c: Fix formatting.
12365 * config/h8300/h8300.h: Likewise.
12366 * config/h8300/h8300.md: Likewise.
12367
39587bb9
ZD
123682002-09-07 Zdenek Dvorak <rakdver@atrey.karlin.mff.cuni.cz>
12369
12370 * cfgcleanup.c (try_crossjump_to_edge): Fix updating of liveness
12371 information.
12372
34146b94 123732002-09-07 Graham Stott <graham.stott@btinternet.com>
92d9256d
GS
12374
12375 * rtlanal.c (dead_or_set_regno_p): Fix typo.
12376
93638d7a
AM
123772002-09-07 Alan Modra <amodra@bigpond.net.au>
12378
fea76d82
AM
12379 * config/rs6000/linux64.h (ASM_PREFERRED_EH_DATA_FORMAT): Define.
12380
93638d7a
AM
12381 * doc/tm.texi (TARGET_ASM_ASSEMBLE_VISIBILITY): Describe.
12382 * target-def.h (TARGET_ASM_ASSEMBLE_VISIBILITY): Define.
12383 (TARGET_ASM_OUT): Add the above here.
12384 * target.h (struct gcc_target): Add "visibility" field.
12385 * varasm.c (maybe_assemble_visibility): Call targetm visibility func.
12386 * config/rs6000/rs6000.c (rs6000_assemble_visibility): New function.
12387 (TARGET_ASM_ASSEMBLE_VISIBILITY): Define.
12388 (rs6000_legitimize_reload_address, first_reg_to_save): Formatting.
12389
370ce32a
ZL
123902002-09-06 Ziemowit Laski <zlaski@apple.com>
12391
12392 * c-lang.c (objc_is_id): New stub.
12393 * c-tree.h (objc_is_id): New forward declaration.
12394 * c-typeck.c (build_c_cast): Do not strip protocol
12395 qualifiers from 'id' type.
12396 * objc/objc-act.c (objc_comptypes): Correct handling
12397 of protocol qualifiers.
12398 (objc_is_id): New.
12399
942579db
JL
12400Fri Sep 6 13:10:08 2002 Jeffrey A Law (law@redhat.com)
12401
54c93c30 12402 * pentium.md (pentium-firstvboth): Fix typo.
942579db 12403
c4dfc70c
DD
124042002-09-06 Dhananjay Deshpande <dhananjayd@kpit.com>
12405
12406 * h8300.c (enum shift_alg): Move to earlier in h8300.c.
12407 (enum shift_type, enum h8_cpu): Likewise.
12408 (INL, ROT, LOP, SPC macros): Likewise.
12409 (shift_alg_qi, shift_alg_hi, shift_alg_si): Likewise. Lose
12410 const designator.
12411 (h8300_init_once): Update shift_alg_{qi,hi,si} to use more
12412 space efficient algorithms when optimize for codesize.
12413
5873a4c1
NP
12414Fri Sep 6 16:35:32 2002 Nicola Pero <n.pero@mi.flashnet.it>
12415
12416 Fix PR/1727 and long-standing failing testcase
12417 objc/formal-protocol-6.m.
12418 * objc-act.c (build_protocol_expr): If compiling for the GNU
12419 runtime, create a list of Protocol statically allocated instances
12420 if it doesn't exist, then add the Protocol object to this same
12421 list.
12422 (get_objc_string_decl): Fixed typo/bug - TREE_VALUE had been used
12423 instead of TREE_CHAIN.
12424
e30d4c82
NP
12425Fri Sep 6 16:17:33 2002 Nicola Pero <n.pero@mi.flashnet.it>
12426
12427 * objc/objc-act.c (dump_interface): Enlarged the char * buffer to
12428 10k. Fixed category dumping - print out category names with the
12429 proper syntax. Print '@end\n' and not '\n@end' at the end of the
12430 interface.
22d4398d 12431 (finish_objc): Fixed the -gen-decls option. It was printing out
e30d4c82
NP
12432 only the last class. Dump an interface declaration of all classes
12433 being compiled instead.
12434
fcd53748
JT
124352002-09-06 Jason Thorpe <thorpej@wasabisystems.com>
12436
2567406a
JH
12437 * config/arm/arm-protos.h (arm_gen_return_addr_mask): New
12438 prototype.
fcd53748
JT
12439 * config/arm/arm.c (arm_gen_return_addr_mask): New function.
12440 * config/arm/arm.h (MASK_RETURN_ADDR): Use arm_gen_return_addr_mask
12441 if not APCS26 and not Thumb or ARMv4-or-higher. Use gen_int_mode
12442 rather than GEN_INT.
12443 * config/arm/arm.md (UNSPEC_CHECK_ARCH): Define.
12444 (return_addr_mask, *check_arch2): New.
12445
96fd3851
UW
124462002-09-06 Ulrich Weigand <uweigand@de.ibm.com>
12447
2567406a 12448 * config/s390/s390.md ("*adddi3_cc", "*adddi3_cconly",
96fd3851 12449 "*adddi3_cconly2", "*adddi3_64", "*adddi3_31", "adddi3",
2567406a 12450 "*addsi3_carry1_cc", "*addsi3_carry1_cconly",
96fd3851
UW
12451 "*addsi3_carry2_cc", "*addsi3_carry2_cconly",
12452 "*addsi3_cc", "*addsi3_cconly", "*addsi3_cconly2", "addsi3",
2567406a 12453 "adddf3", "*adddf3", "*adddf3_ibm",
96fd3851
UW
12454 "addsf3", "*addsf3", "*addsf3_ibm",
12455 "muldi3", "mulsi3", "mulsidi3",
12456 "muldf3", "*muldf3", "*muldf3_ibm",
12457 "mulsf3", "*mulsf3", "*mulsf3_ibm",
12458 "*anddi3_cc", "*anddi3_cconly", "anddi3",
12459 "*andsi3_cc", "*andsi3_cconly", "andsi3",
12460 "*iordi3_cc", "*iordi3_cconly", "iordi3",
12461 "*iorsi3_cc", "*iorsi3_cconly", "iorsi3",
12462 "*xordi3_cc", "*xordi3_cconly", "xordi3",
12463 "*xorsi3_cc", "*xorsi3_cconly", "xorsi3"): Use "nonimmediate_operand"
12464 instead of "register_operand" as predicate for "%0" operand.
12465
22252625
JJ
124662002-09-06 Jakub Jelinek <jakub@redhat.com>
12467
12468 * configure.in (HAVE_AS_OFFSETABLE_LO10): Use -xarch=v9
12469 unconditionally when gcc_cv_as_flags64 checks are gone.
12470 * configure: Rebuilt.
12471
bc401279
AM
124722002-09-06 Alan Modra <amodra@bigpond.net.au>
12473
12474 * config/rs6000/rs6000.md (extzvsi_internal2): Revert most of
12475 2002-07-26 change. Comment.
12476
b3fbfc07
KG
124772002-09-05 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
12478
12479 * frv.c (frv_unique_section, frv_select_section,
12480 frv_select_rtx_section): Delete.
12481 (frv_in_small_data_p): New.
12482 (TARGET_ASM_UNIQUE_SECTION, TARGET_ASM_SELECT_SECTION,
12483 TARGET_ASM_SELECT_RTX_SECTION): Delete.
12484 (TARGET_IN_SMALL_DATA_P): Define.
12485
41e34bab
DJ
124862002-09-05 Dale Johannesen <dalej@apple.com>
12487
12488 * reload1.c (reload): Retain only those memory clobbers
12489 added for variable-array handling.
12490
dc0ba55a
JT
124912002-09-05 Jason Thorpe <thorpej@wasabisystems.com>
12492
12493 * config/arm/arm.c (arm_return_in_memory): Implement ATPCS
2567406a 12494 return-in-memory rules.
dc0ba55a
JT
12495 * config/arm/arm.h (ARM_FLAG_ATPCS, TARGET_ATPCS): Define.
12496
dd19d142
DE
124972002-09-05 David Edelsohn <edelsohn@gnu.org>
12498
12499 * config/rs6000/xcoff.h (HOT_TEXT_SECTION_NAME): Delete.
12500 (UNLIKELY_EXECUTED_TEXT_SECTION_NAME): Delete.
12501
3717da94
JT
125022002-09-05 Jason Thorpe <thorpej@wasabisystems.com>
12503
12504 * real.c: Avoid parse error if FLOAT_WORDS_BIG_ENDIAN is
12505 not a compile-time constant for the non-IBM case.
12506 * config/arm/arm-protos.h (arm_float_words_big_endian): New
2567406a 12507 prototype.
3717da94 12508 * config/arm/arm.c (arm_float_words_big_endian): New function.
b5b620a4 12509 * config/arm/arm.h (TARGET_CPU_CPP_BUILTINS): Define __VFP_FP__
2567406a
JH
12510 if TARGET_VFP and not TARGET_HARD_FLOAT.
12511 (ARM_FLAG_VFP, TARGET_VFP): Define.
3717da94
JT
12512 (FLOAT_WORDS_BIG_ENDIAN): Use arm_float_words_big_endian.
12513
225cee28
DE
125142002-09-05 David Edelsohn <edelsohn@gnu.org>
12515
12516 * doc/install.texi: Correct text of s390-*-linux* and s390x-*-linux*
12517 URLs. Fix AIX wording.
12518
c72bfda7
SS
125192002-09-05 Stan Shebs <shebs@apple.com>
12520
12521 * config/rs6000/rs6000.c (rs6000_override_options): Make -fpic and
12522 -fPIC equivalent on Darwin.
12523
3578cf63
R
12524Thu Sep 5 16:27:47 2002 J"orn Rennecke <joern.rennecke@superh.com>
12525
12526 * sh.c (sh_expand_builtin): Return early if encountering an
12527 error_mark for a type.
12528
7974fe63
UW
125292002-09-05 Ulrich Weigand <uweigand@de.ibm.com>
12530
12531 * config/s390/s390.c (s390_expand_plus_operand): Do not require
12532 double-word scratch register.
12533 config/s390/s390.md ("reload_indi", "reload_insi"): Adapt.
12534
2567406a 12535 ("*tmqi_ext", "*tmdi_mem", "*tmsi_mem", "*tmhi_mem", "*tmqi_mem",
7974fe63
UW
12536 "*cli"): Replace s_operand by memory_operand.
12537 ("cmpstrdi", "cmpstrsi"): Replace s_operand by general_operand.
12538
f8cb5851
KH
125392002-09-05 Kazu Hirata <kazu@cs.umass.edu>
12540
12541 * config/h8300/h8300.c (asm_file_start): Add a missing
12542 semicolon.
12543
4977bab6
ZW
125442002-09-04 Volker Reichelt <reichelt@igpm.rwth-aachen.de>
12545
12546 * c-typeck.c (build_function_call): Remove unused variable(s).
12547 (build_c_cast): Likewise.
12548 * calls.c (rtx_for_function_call): Likewise.
12549 * cfglayout.c (duplicate_insn_chain): Likewise.
12550 * cfgloop.c (flow_loop_nodes_find): Likewise.
12551 * cfgrtl.c (split_edge): Likewise.
12552 * df.c (df_ref_create): Likewise.
12553 * except.c (expand_end_catch): Likewise.
12554 * expr.c (emit_push_insn, store_constructor, expand_expr): Likewise.
12555 * function.c (emit_return_into_block): Likewise.
12556 (reposition_prologue_and_epilogue_notes): Likewise.
12557 * gengtype.c (get_file_basename, write_gc_structure_fields): Likewise.
12558 * combine.c (subst_prev_insn, need_refresh): Remove.
12559 * dwarf2out.c (primary_filename): Remove.
12560 * final.c (new_block): Remove.
12561 * gcse.c (orig_bb_count): Remove.
12562
125632002-09-04 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
12564
12565 * dsp16xx-protos.h (dsp16xx_compare_gen): Change to bool.
12566 * dsp16xx.c (dsp16xx_compare_gen): Likewise.
12567 * dsp16xx.md: Treat dsp16xx_compare_gen as a bool. Call functions
12568 directly instead of using a function pointer.
12569
5fc0e5df
KW
125702002-09-04 Krister Walfridsson <cato@df.lth.se>
12571
12572 * config/i386/i386.h (GOT_SYMBOL_NAME): Define.
12573 * config/i386/i386.c (output_set_got): Use GOT_SYMBOL_NAME.
12574 (ix86_output_addr_diff_elt) Likewise.
12575 (x86_output_mi_thunk) Likewise.
12576 * config/i386/netbsd.h (GOT_SYMBOL_NAME): Redefine.
12577
f4b488fd
KG
125782002-09-04 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
12579
12580 * frv.c (frv_encode_section_info): Fix error in last change.
12581
0e5dbd9b
DE
125822002-09-04 David Edelsohn <edelsohn@gnu.org>
12583
12584 * config/rs6000/rs6000.c (rs6000_flag_pic): New variable.
12585 (rs6000_elf_encode_section_info): ATTRIBUTE_UNUSED.
12586 (TARGET_BINDS_LOCAL_P): Define.
12587 (rs6000_override_options): Save original flag_pic value.
12588 (rs6000_elf_select_section): Call default_elf_select_section_1.
12589 (rs6000_elf_unique_section): Call default_unique_section_1.
12590 (rs6000_elf_in_small_data_p): New function.
12591 (rs6000_xcoff_asm_named_section): Determine storage mapping class.
12592 (rs6000_xcoff_select_section): Update based on defaults.
12593 (rs6000_xcoff_unique_section): Set to basic name if not common.
12594 (rs6000_binds_local_p): New function.
12595 * config/rs6000/sysv4.h (SUBTARGET_OVERRIDE_OPTIONS): Set
12596 targetm.have_srodata_section if SDATA_EABI.
12597 (TARGET_IN_SMALL_DATA_P): Define.
12598
f57f9cb8
DJ
125992002-09-04 Dale Johannesen <dalej@apple.com>
12600
12601 * varasm.c (struct rtx_const, decode_rtx_const):
12602 Make veclo and vechi fields not share storage.
12603
ed6cc1f5
R
12604Thu Sep 5 00:34:33 2002 J"orn Rennecke <joern.rennecke@superh.com>
12605
12606 * loop.c (scan_loop): Don't mark separate insns out of a libcall
12607 for moving.
12608 (move_movables): Abort if we see the first insn of a libcall.
12609
ab5e2615
RH
126102002-09-04 Richard Henderson <rth@redhat.com>
12611
12612 * builtin-types.def (BT_FN_FLOAT): New.
12613 (BT_FN_DOUBLE, BT_FN_LONG_DOUBLE): New.
12614 * builtins.def (BUILT_IN_INF, BUILT_IN_INFF, BUILT_IN_INFL,
12615 BUILT_IN_HUGE_VAL, BUILT_IN_HUGE_VALF, BUILT_IN_HUGE_VALL): New.
12616 * builtins.c (fold_builtin_inf): New.
12617 (fold_builtin): Call it.
12618 * real.c (ereal_inf): New.
12619 * real.h: Declare it.
12620 * doc/extend.texi: Document new builtins.
12621
9beb7d20
RH
126222002-09-04 Richard Henderson <rth@redhat.com>
12623
12624 * cse.c (cse_insn): Avoid subreg games if the equivalence
12625 is already in the proper mode.
12626
29984e05
EB
126272002-09-04 Eric Botcazou <ebotcazou@multimania.com>
12628
12629 PR c/7102
12630 * optabs.c (expand_binop): Convert CONST_INTs in all cases.
12631
8d46398e
JDA
126322002-09-04 John David Anglin <dave@hiauly1.hia.nrc.ca>
12633
12634 * pa.md (setccfp0, setccfp1): New patterns.
12635
14966b94
KG
126362002-09-04 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
12637
12638 * frv-protos.h (frv_init_builtins, frv_expand_builtin,
12639 frv_select_section, frv_select_rtx_section,
12640 frv_encode_section_info, frv_unique_section): Delete.
12641 * frv.c: Update for target hooks.
12642 * frv.h (STRIP_NAME_ENCODING, SLOW_ZERO_EXTEND, SELECT_SECTION,
12643 SELECT_RTX_SECTION, ENCODE_SECTION_INFO, UNIQUE_SECTION,
12644 EASY_DIV_EXPR, MD_INIT_BUILTINS, MD_EXPAND_BUILTIN): Delete.
12645
c8bf1a1a
KG
126462002-09-04 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
12647
12648 * ip2k-protos.h (function_prologue, function_epilogue,
12649 encode_section_info): Update to match target hook specification.
12650 * ip2k.c: Wrap `MDR' code in IP2K_MD_REORG_PASS.
12651 (function_prologue, function_epilogue, encode_section_info):
12652 Update to match target hook specification.
12653 * ip2k.h (SELECT_SECTION, SELECT_RTX_SECTION, ASM_OPEN_PAREN,
12654 ASM_CLOSE_PAREN, EASY_DIV_EXPR): Delete.
12655 (NOTICE_UPDATE_CC): Cast to void.
12656 * ip2k.md: Add defaults in switch statements.
12657
0484cb35
JJ
126582002-09-04 Janis Johnson <janis187@us.ibm.com>
12659
12660 * doc/trouble.texi (Interoperation): Update information about C++ ABI
12661 issues.
12662
3e62bd08
JT
126632002-09-04 Jason Thorpe <thorpej@wasabisystems.com>
12664
12665 * config/sparc/t-netbsd64: Disable multilib for now.
12666
275b6d80
DE
126672002-09-04 David Edelsohn <edelsohn@gnu.org>
12668
12669 * target-def.h (TARGET_HAVE_SRODATA_SECTION): New macro.
12670 * target.h (gcc_target): Add have_srodata_section member.
12671 * varasm.c (section_category): Add SECCAT_SRODATA.
12672 (categorize_decl_for_section): Return SECCAT_SRODATA for sdata if
12673 READONLY_SDATA_SECTION defined.
12674 (decl_readonly_section_1): True for SECCAT_SRODATA also.
12675 (default_elf_select_section_1): Map SECCAT_SRODATA to .sdata2.
12676 (default_unique_section_1): Likewise.
12677
015b1ad1
JDA
126782002-09-04 John David Anglin <dave@hiauly1.hia.nrc.ca>
12679
12680 * expr.c (emit_group_load): Revise to allow splitting TCmode source
12681 into DImode pieces.
12682
12683 * pa-64.h (LONG_DOUBLE_TYPE_SIZE): Define to 128.
12684 * pa64-regs.h (CLASS_CANNOT_CHANGE_MODE_P): Inhibit changes from SImode
12685 for floating-point register class.
12686 * pa.c (function_arg): Fix handling of modes wider than one word for
12687 TARGET_64BIT.
12688
b10f2187
R
12689Wed Sep 4 18:48:10 2002 J"orn Rennecke <joern.rennecke@superh.com>
12690
12691 * combine.c (make_compound_operation): Don't generate zero / sign
12692 extensions in floating point modes.
12693
478c9e72
JJ
126942002-09-04 Janis Johnson <janis187@us.ibm.com>
12695
12696 * doc/c-tree.texi: Fix overfull hboxes.
12697 * doc/cppopts.texi: Ditto.
12698 * doc/extend.texi: Ditto.
12699 * doc/gty.texi: Ditto.
12700 * doc/invoke.texi: Ditto.
12701 * doc/makefile.texi: Ditto.
12702 * doc/rtl.texi: Ditto.
12703 * doc/standards.texi: Ditto.
12704 * doc/tm.texi: Ditto.
12705
77e8a0cc
RH
127062002-09-04 Richard Henderson <rth@redhat.com>
12707
12708 * c-common.c (builtin_define_with_hex_fp_value): New.
12709 (builtin_define_float_constants): Use it. Fix H_FLOAT mant_dig.
12710
a9c60612
JJ
127112002-09-04 Janis Johnson <janis187@us.ibm.com>
12712
12713 * doc/invoke.texi (-fshort-wchar): Move to Code Generation Options.
12714 (-fpcc-struct-return, -freg-struct-return, -fshort-enums,
12715 -fshort-double, -fshort-wchar, -fpack-struct, -fleading-underscore):
12716 Warn that these options can break ABI compatibility.
12717
4b67a274
RH
127182002-09-04 Richard Henderson <rth@redhat.com>
12719
12720 * real.c (ereal_to_decimal): Add digits parameter.
12721 * real.h (REAL_VALUE_TO_DECIMAL): Remove format; add digits parameter.
12722 * c-pretty-print.c (pp_c_real_literal): Update call.
12723 * print-rtl.c (print_rtx): Likewise.
12724 * print-tree.c (print_node_brief, print_node): Likewise.
12725 * sched-vis.c (print_value): Likewise.
12726 * config/arc/arc.c (arc_print_operand): Likewise.
12727 * config/c4x/c4x.c (c4x_print_operand): Likewise.
12728 * config/i370/i370.h (PRINT_OPERAND): Likewise.
12729 * config/i386/i386.c (print_operand): Likewise.
12730 * config/i960/i960.c (i960_print_operand): Likewise.
12731 * config/ip2k/ip2k.c (asm_output_float): Likewise.
12732 * config/m32r/m32r.c (m32r_print_operand): Likewise.
12733 * config/m68hc11/m68hc11.c (print_operand): Likewise.
12734 * config/m68k/hp320.h (PRINT_OPERAND, ASM_OUTPUT_FLOAT_OPERAND,
12735 ASM_OUTPUT_DOUBLE_OPERAND, ASM_OUTPUT_LONG_DOUBLE_OPERAND): Likewise.
2567406a 12736 * config/m68k/m68k.h (ASM_OUTPUT_FLOAT_OPERAND,
4b67a274
RH
12737 ASM_OUTPUT_DOUBLE_OPERAND, ASM_OUTPUT_LONG_DOUBLE_OPERAND): Likewise.
12738 * config/m68k/sun2o4.h (ASM_OUTPUT_FLOAT_OPERAND,
12739 ASM_OUTPUT_DOUBLE_OPERAND): Likewise.
12740 * config/m68k/sun3.h (ASM_OUTPUT_FLOAT_OPERAND,
12741 ASM_OUTPUT_DOUBLE_OPERAND): Likewise.
12742 * config/mips/mips.c (print_operand): Likewise.
12743 * config/ns32k/ns32k.c (print_operand): Likewise.
12744 * config/pdp11/pdp11.h (PRINT_OPERAND): Likewise.
12745 * config/vax/vax.h (PRINT_OPERAND): Likewise.
12746 * doc/tm.texi (REAL_VALUE_TO_DECIMAL): Update docs.
12747
01abf342
BW
127482002-09-04 Bob Wilson <bob.wilson@acm.org>
12749
12750 * config/xtensa/elf.h (TARGET_SECTION_TYPE_FLAGS): Define to
12751 xtensa_multibss_section_type_flags.
12752 * config/xtensa/xtensa.c (xtensa_multibss_section_type_flags): Define.
12753
cd42d3df
RH
127542002-09-04 Richard Henderson <rth@redhat.com>
12755
12756 * doc/install-old.texi: Don't mention enquire.
12757 * doc/sourcebuild.texi: Update float.h description.
12758
502e6d5a
R
12759Wed Sep 4 11:22:14 2002 J"orn Rennecke <joern.rennecke@superh.com>
12760
12761 * sh.md (mperm_w_little, mperm_w_big): Supply mode for zero_extract.
12762
4977bab6
ZW
127632002-09-03 Roger Sayle <roger@eyesopen.com>
12764
12765 * builtins.c (build_function_call_expr): Remove prototype, export
12766 as non-static and add a comment above function definition.
12767 (builtin_mathfn_code): New function to check for math builtins.
12768 (fold_builtin): Optimize sqrt(0.0) as 0.0, sqrt(1.0) as 1.0,
12769 exp(0.0) as 1.0, and log(1.0) as 0.0. Optimize exp(log(x)) and
12770 log(exp(x)) as x. Optimize sqrt(exp(x)) as exp(x/2.0) and
12771 log(sqrt(x)) as log(x)/2.0.
12772
12773 * tree.h: Prototype build_function_call_expr and builtin_mathfn_code
12774 in new "builtins.c" section. Place the build_range_type prototype
12775 with the other prototypes from "tree.c".
12776
12777 * fold-const.c (fold) [ABS_EXPR]: Fold fabs(sqrt(x)) as sqrt(x)
12778 and fabs(exp(x)) as exp(x). [MULT_EXPR]: Fold sqrt(x)*sqrt(y)
12779 as sqrt(x*y) and exp(x)*exp(y) as exp(x+y). [RDIV_EXPR]: Fold
12780 x/exp(y) as x*exp(-y).
12781
2cc9fb4c
DE
127822002-09-03 David Edelsohn <edelsohn@gnu.org>
12783
12784 * varasm.c (default_section_type_flags): Append _1 to name with
12785 shlib parameter. Use original name to call new function with
12786 implicit flag_pic.
12787 (decl_readonly_section): Likewise.
12788 (default_elf_select_section): Likewise.
12789 (default_unique_section): Likewise.
12790 (default_bind_local_p): Likewise.
12791 (categorize_decl_for_section): Add shlib parameter to use in place
12792 of implicit flag_pic.
12793 * output.h: Declare new functions with _1 and shlib argument.
12794
7c19f816
JJ
127952002-09-03 Janis Johnson <janis187@us.ibm.com>
12796
8c085f6f
JJ
12797 * doc/install.texi: Fix typos, formatting problems, and obvious
12798 overfull/underfull boxes.
12799
7c19f816
JJ
12800 * Makefile.in (TEXI_GCC_FILES): Add compat.texi.
12801 * doc/gcc.texi (Top): Add new chapter, Binary Compatibility, and
12802 include its file, compat.texi.
12803 * doc/compat.texi: New file with new chapter, Binary Compatibility.
12804
79ba5e3b
NB
128052002-09-03 Neil Booth <neil@daikokuya.co.uk>
12806
12807 Debian BTS Bug #157416
12808 * cpphash.h (FIRST, LAST, CUR, RLIMIT): Fix definitions.
12809 * cpplib.c (destringize_and_run): Kludge around getting
12810 tokens from in-progress macros.
12811 (_cpp_do__Pragma): Simplify.
12812
57016b47
SE
128132002-09-03 Steve Ellcey <sje@cup.hp.com>
12814
12815 * config/ia64/ia64.h (EXTRA_SPECS): Remove cpp_cpu.
12816 (CPP_CPU_SPEC): Remove.
12817 (TARGET_CPU_CPP_BUILTINS): New.
12818 * config/ia64/hpux.h (CPP_PREDEFINES): Remove.
12819 (CPP_SPEC): Remove.
12820 (TARGET_OS_CPP_BUILTINS): New.
12821 * config/ia64/linux.h (CPP_PREDEFINES): Remove.
12822 (TARGET_OS_CPP_BUILTINS): New.
12823 * config/ia64/aix.h (CPP_SPEC): Move some stuff to
12824 TARGET_OS_CPP_BUILTINS.
12825 (CPP_PREDEFINES): Remove.
12826 (CPLUSPLUS_CPP_SPEC): Remove.
12827 (TARGET_OS_CPP_BUILTINS): New.
12828
d57a4b98
RH
128292002-09-03 Richard Henderson <rth@redhat.com>
12830
12831 * Makefile.in (USER_H): Add ginclude/float.h.
12832 (FLOAT_H): Remove.
12833 (stmp-int-hdrs, install-mkheaders): Don't handle FLOAT_H.
12834 (mostlyclean): Don't remove float.h intermediate files.
12835 (distclean): Don't remove float.h.
12836 * config.gcc: Remove all float_format references.
12837 * configure.in (float_format, float_h_file): Remove.
12838
12839 * c-common.c: Include tree-inline.h.
12840 (builtin_define_with_int_value): New.
12841 (builtin_define_type_precision): Use it.
12842 (builtin_define_float_constants): New.
12843 (cb_register_builtins): Use it. Define __FLT_RADIX__ and
12844 __FLT_EVAL_METHOD__.
12845 * defaults.h (TARGET_FLT_EVAL_METHOD): New.
12846 * config/i386/i386.h (TARGET_FLT_EVAL_METHOD): New.
12847 * config/m68k/m68k.h (TARGET_FLT_EVAL_METHOD): New.
12848 * doc/tm.texi (INTEL_EXTENDED_IEEE_FORMAT): Mention moto 96-bit format.
12849 (TARGET_FLT_EVAL_METHOD): New.
12850
12851 * config/float-c4x.h, config/float-i128.h, config/float-i32.h,
12852 config/float-i386.h, config/float-i64.h, config/float-m68k.h,
12853 config/float-sh.h, config/float-sparc.h, config/float-vax.h: Remove.
12854 * ginclude/float.h: New.
12855
527347f0
SS
128562002-09-03 Stan Shebs <shebs@apple.com>
12857
12858 * config/darwin.h (WARN_FOUR_CHAR_CONSTANTS): Remove, never used.
12859 (DWARF2_DEBUGGING_INFO): Remove until assembler accepts Dwarf-2.
12860 (PREFERRED_DEBUGGING_TYPE): Ditto.
12861 (ASM_OUTPUT_IDENT): Remove empty definition.
12862
34c1864f
SE
128632002-09-03 Steve Ellcey <sje@cup.hp.com>
12864
12865 * config.gcc (ia64*-*-hpux*): Add ia64-c.o to c_target and
12866 cxx_target.
12867 * config/ia64/hpux.h (REGISTER_TARGET_PRAGMAS): Register pragma
12868 handling routine for builtin pragma.
12869 * config/ia64/ia64-protos.h (ia64_hpux_handle_builtin_pragma):
12870 Registered pragma handling routine.
12871 * ia64-c.c (ia64_hpux_handle_builtin_pragma): Ditto.
12872 (ia64_hpux_add_pragma_builtin) New subroutine used by above.
12873 If builtin pragma seen for math routine and C89 conformance is
12874 requested use different math function in order to set errno.
12875 * t-ia64 (ia64-c.o): Add new rule for new file.
12876
9b7c75b9
UW
128772002-09-03 Ulrich Weigand <uweigand@de.ibm.com>
12878
12879 * config/s390/s390.md ("movti"): Add Q->Q alternative.
12880 ("*movdi_64", "*movdi_31", "*movsi", "movhi", "movqi_64",
12881 "movqi", "*movdf_64", "*movdf_31", "*movsf"): Likewise.
2567406a
JH
12882
12883 ("*movti_ss", "*movdi_ss", "*movsi_ss", "*movdf_ss",
9b7c75b9
UW
12884 "*movsf_ss"): Remove.
12885
710ba35f
JDA
128862002-09-03 John David Anglin <dave@hiauly1.hia.nrc.ca>
12887
12888 * pa32-regs.h (CLASS_CANNOT_CHANGE_MODE, CLASS_CANNOT_CHANGE_MODE_P):
12889 Delete macros.
12890
ff970081
AD
128912002-09-03 Arati Dikey <aratid@kpit.com>
12892
12893 * h8300.c (asm_file_start): Corrected optimization comment.
12894
b50d021d
SS
128952002-09-03 Stan Shebs <shebs@apple.com>
12896
12897 * c-lang.c (recognize_objc_keyword): Remove, no longer used.
12898 * c-tree.h (recognize_objc_keyword): Remove decl.
12899 * c-typeck.c (comp_target_types): Update a comment.
12900
b808c04c
UW
129012002-09-03 Ulrich Weigand <uweigand@de.ibm.com>
12902
12903 * config/s390/s390.c (s390_decompose_address): Remove STRICT parameter
12904 and register validity checks.
12905 (general_s_operand): Adapt to s390_decompose_address interface change.
12906 (q_constraint): Likewise.
12907 (s390_expand_plus_operand): Likewise.
12908 (legitimiate_address_p): Likewise.
12909 (legitimate_la_operand_p): Likewise.
12910 (legitimize_la_operand): Likewise.
12911 (print_operand_address): Likewise.
12912 (print_operand): Likewise.
12913
ee453219
NP
12914Tue Sep 3 11:32:14 2002 Nicola Pero <n.pero@mi.flashnet.it>
12915
12916 PR objc/5956:
12917 * objc/objc-act.c (build_typed_selector_reference): Fix typo which
2567406a
JH
12918 was causing the new selector never to match the existing ones
12919 (Patch by Alexander Malmberg <alexander@malmberg.org>).
ee453219 12920
d82283d5
GS
129212002-09-03 Graham Stott <graham.stott@btinternet.com>
12922
12923 * config/i386/i386.md ("femms"): Add "memory" attr "none".
12924
129252002-09-03 Graham Stott <graham.stott@btinternet.com>
c7a009a2
GS
12926
12927 * expr.c (expand_expr): Remove extraneous comment and code.
12928
4977bab6
ZW
129292002-09-02 Nathan Sidwell <nathan@codesourcery.com>
12930
12931 * stor-layout (finish_builtin_struct): Renamed and moved from c++
12932 frontend. Take chain of fields. Allow NULL alignment type.
12933 * tree.h (finish_builtin_struct): Declare.
12934
129352002-09-01 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
12936
12937 * config/alpha/alpha.c config/alpha/alpha.h config/alpha/alpha.md
12938 config/alpha/elf.h config/alpha/unicosmk.h config/alpha/vms.h
12939 config/arc/arc.c config/arc/arc.h config/arm/aout.h
12940 config/arm/arm.c config/arm/arm.h config/arm/arm.md
12941 config/avr/avr.h config/d30v/d30v.h config/dbxcoff.h
12942 config/dbxelf.h config/elfos.h config/fr30/fr30.h config/frv/frv.h
12943 config/i386/i386.c config/i386/i386.md config/i386/sco5.h
12944 config/ia64/ia64.h config/ip2k/ip2k.h config/m68hc11/m68hc11.md
12945 config/m68k/hp320.h config/m68k/m68k.c config/m68k/m68k.md
12946 config/m68k/mot3300.h config/m68k/sgs.h config/m68k/tower-as.h
12947 config/m88k/m88k.c config/m88k/m88k.h config/mcore/mcore-pe.h
12948 config/mcore/mcore.c config/mips/mips.c config/mips/mips.h
12949 config/ns32k/ns32k.md config/pa/pa-linux.h config/pa/pa.c
12950 config/pa/pa.h config/pa/pa.md config/romp/romp.h
12951 config/rs6000/linux64.h config/rs6000/lynx.h
12952 config/rs6000/rs6000.c config/rs6000/sysv4.h config/rs6000/xcoff.h
12953 config/s390/s390.c config/s390/s390.md config/sh/sh.c
12954 config/sparc/sparc.c config/sparc/sysv4.h
12955 config/stormy16/stormy16.h dbxout.c defaults.h dwarf2out.c
12956 dwarfout.c except.c final.c varasm.c vmsdbgout.c: Replace
12957 ASM_OUTPUT_INTERNAL_LABEL macro with a call to the target hook.
12958
12959 * doc/tm.texi: Update docs.
12960 * default.h (ASM_OUTPUT_INTERNAL_LABEL): Don't define.
12961 * system.h (ASM_OUTPUT_INTERNAL_LABEL): Poison.
12962
129632002-08-31 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
12964
12965 * Makefile.in (sdbout.o, insn-output.o): Depend on $(TARGET_H).
12966 * arc.c (arc_internal_label): New function.
12967 (TARGET_ASM_INTERNAL_LABEL): Set.
12968 * arc.h (ASM_OUTPUT_INTERNAL_LABEL): Delete.
12969 * arm.c (arm_internal_label): New function.
12970 (TARGET_ASM_INTERNAL_LABEL): Set.
12971 * arm.h (ASM_OUTPUT_INTERNAL_LABEL): Delete.
12972 * arm/elf.h (ASM_OUTPUT_INTERNAL_LABEL): Delete.
12973 * i370.c (i370_internal_label): New function.
12974 (TARGET_ASM_INTERNAL_LABEL): Set.
12975 * i370.h (ASM_OUTPUT_INTERNAL_LABEL): Delete.
12976 * m68k/hp320.h (ASM_OUTPUT_INTERNAL_LABEL): Delete.
12977 * m68k.c (m68k_hp320_internal_label): New function.
12978 (TARGET_ASM_INTERNAL_LABEL): Set.
12979 * m88k.c (m88k_internal_label): New function.
12980 (TARGET_ASM_INTERNAL_LABEL): Set.
12981 * m88k.h (ASM_OUTPUT_INTERNAL_LABEL): Delete.
12982 * defaults.h (ASM_OUTPUT_INTERNAL_LABEL): Set to target hook.
12983 * genoutput.c (output_prologue): Include target.h in output file.
12984 * output.h (default_internal_label): Declare.
12985 * sdbout.c: Include target.h.
12986 * target-def.h (TARGET_ASM_INTERNAL_LABEL): Set and add to
12987 TARGET_ASM_OUT.
12988 * target.h (internal_label): Add to struct gcc_target.
12989 * varasm.c (default_internal_label): New function.
12990
129912002-08-31 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
12992
12993 * alpha.h (ASM_OUTPUT_INTERNAL_LABEL): Delete.
12994 * avr.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
12995 * c4x.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
12996 * cris.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
12997 * d30v.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
12998 * darwin.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
12999 * dsp16xx.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
13000 * elfos.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
13001 * h8300.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
13002 * i386/att.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
13003 * i386/bsd.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
13004 * i386/i386-coff.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
13005 * i386/lynx-ng.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
13006 * i386/lynx.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
13007 * i386/sco5.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
13008 * i960/i960.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
13009 * m68k/3b1.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
13010 * m68k/amix.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
13011 * m68k/atari.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
13012 * m68k.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
13013 * m68k/mot3300.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
13014 * m68k/tower-as.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
13015 * m88k.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
13016 * mcore.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
13017 * mips.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
13018 * mmix-protos.h (mmix_asm_output_internal_label): Likewise.
13019 * mmix.c (mmix_asm_output_internal_label): Likewise.
13020 * mmix.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
13021 * ns32k.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
13022 * pa.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
13023 * pdp11.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
13024 * romp.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
13025 * rs6000/xcoff.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
13026 * sh/coff.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
13027 * sh/elf.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
13028 * sparc/freebsd.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
13029 * sparc/linux.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
13030 * sparc/linux64.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
13031 * sparc/netbsd-elf.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
13032 * sparc/pbd.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
13033 * sparc/sol2.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
13034 * sparc.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
13035 * sparc/vxsim.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
13036 * stormy16.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
13037 * svr3.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
13038 * vax.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
13039
13040 * defaults.h (ASM_OUTPUT_INTERNAL_LABEL): Define.
13041
98c0d8d1
RH
130422002-08-31 Richard Henderson <rth@redhat.com>
13043
13044 * expr.c (block_move_libcall_safe_for_call_parm): Fix thinko.
13045
a5f3f0ab
JDA
130462002-08-31 John David Anglin <dave@hiauly1.hia.nrc.ca>
13047
13048 * pa.c (pa_globalize_label): Add ATTRIBUTE_UNUSED to prototype.
13049
38ec83b1
RH
130502002-08-30 Richard Henderson <rth@redhat.com>
13051
c9989d09 13052 PR opt/7515
38ec83b1
RH
13053 * c-objc-common.c: Include target.h.
13054 (c_cannot_inline_tree_fn): Don't auto-inline functions that
13055 don't bind locally. Factor setting DECL_UNINLINABLE.
13056 * Makefile.in (c-objc-common.o): Update.
13057
4c64396e
JJ
130582002-08-30 Janis Johnson <janis187@us.ibm.com>
13059
13060 * doc/install.texi (Configuration, Building): Fix a typo and
13061 some formatting directives.
13062
4226378a
PK
130632002-08-30 Paul Koning <pkoning@equallogic.com>
13064
13065 * doc/c-tree.texi (RDIV_EXPR): Fix typo.
13066 * doc/rtl.texi (post_modify): Remove misplaced text, remove "not
13067 implemented" note.
13068 * doc/md.texi (IP2K): Move machine-specific constraints before MIPS
13069 for alphabetic order.
13070 * doc/tm.texi (TARGET_FLOAT_FORMAT): Update description for
13071 VAX_FLOAT_FORMAT. Remove reference to HOST_FLOAT_FORMAT.
13072 (VAX_HALFWORD_ORDER): Document.
13073 (LARGEST_EXPONENT_IS_NORMAL): Remove note about being only for
13074 IEEE float format.
13075 (TARGET_SCHED_ISSUE_RATE): Reword reference to MAX_DFA_ISSUE_RATE.
13076 (ASM_OUTPUT_LABEL_REF): Fix font.
13077 (CASE_VECTOR_SHORTEN_MODE): Ditto.
13078
b8074dbe
DC
130792002-08-30 Denis Chertykov <denisc@overta.ru>
13080
13081 * config/ip2k/ip2k.c (ip2k_set_compare): Remove all const_double
13082 stuff.
13083 (ip2k_gen_unsigned_comp_branch): Handle CONST_INT and
13084 CONST_DOUBLE constants.
2567406a 13085
55f49e3d
JT
130862002-08-30 Jason Thorpe <thorpej@wasabisystems.com>
13087
13088 * config/alpha/alpha.h (TARGET_CPU_CPP_BUILTINS): Move language-
13089 related defines to...
13090 (SUBTARGET_LANGUAGE_CPP_BUILTINS): ...here.
13091 * config/alpha/netbsd.h (SUBTARGET_LANGUAGE_CPP_BUILTINS): Redefine
13092 as a no-op.
13093
e1944073
KW
130942002-08-30 Krister Walfridsson <cato@df.lth.se>
13095
13096 * config/arm/arm.c (arm_asm_output_labelref): New function.
13097 * config/arm/arm.h (ASM_OUTPUT_LABELREF): Call arm_asm_output_labelref.
13098 * config/arm/arm-protos.h: Add prototype for arm_asm_output_labelref.
13099
6e92b3a1
RB
131002002-08-29 Rodney Brown <rbrown64@csc.com.au>
13101
13102 * doc/install.texi (Specific, alpha*-dec-osf*): Add "virtual
13103 memory exhausted" workarounds.
13104
9d533cb5
GDR
131052002-08-30 Gabriel Dos Reis <gdr@integrable-solutions.net>
13106
13107 * diagnostic.c (fancy_abort): Don't repeat "internal error".
13108 * toplev.c (crash_signal): Likewise.
13109
1f676100
NP
13110Fri Aug 30 00:33:37 2002 Nicola Pero <n.pero@mi.flashnet.it>
13111
13112 * doc/cpp.texi (__NEXT_RUNTIME__): Extended documentation.
13113 * doc/invoke.texi (-fnext-runtime, -Wno-protocol, -Wselector):
13114 Extended, updated documentation.
13115 (-Wundeclared-selector): Documented.
13116
23532de9
JT
131172002-08-29 Jason Thorpe <thorpej@wasabisystems.com>
13118
13119 * config/chorus.h: Consistently define *_DEBUGGING_INFO with
13120 the value 1. Do not undef before defining.
13121 * config/darwin.h: Likewise.
13122 * config/dbx.h: Likewise.
13123 * config/dbxcoff.h: Likewise.
13124 * config/dbxelf.h: Likewise.
13125 * config/elfos.h: Likewise.
13126 * config/interix.h: Likewise.
13127 * config/lynx-ng.h: Likewise.
13128 * config/lynx.h: Likewise.
13129 * config/netware.h: Likewise.
13130 * config/psos.h: Likewise.
13131 * config/svr3.h: Likewise.
13132 * config/alpha/alpha.h: Likewise.
13133 * config/alpha/elf.h: Likewise.
13134 * config/alpha/vms.h: Likewise.
13135 * config/arc/arc.h: Likewise.
13136 * config/arm/aout.h: Likewise.
13137 * config/arm/coff.h: Likewise.
13138 * config/c4x/c4x.h: Likewise.
13139 * config/h8300/h8300.h: Likewise.
13140 * config/i386/cygwin.h: Likewise.
13141 * config/i386/djgpp.h: Likewise.
13142 * config/i386/gas.h: Likewise.
13143 * config/i386/gstabs.h: Likewise.
13144 * config/i386/i386-coff.h: Likewise.
13145 * config/i386/i386-interix.h: Likewise.
13146 * config/i386/sco5.h: Likewise.
13147 * config/i386/svr3dbx.h: Likewise.
13148 * config/i386/sysv3.h: Likewise.
13149 * config/i386/win32.h: Likewise.
13150 * config/i386/x86-64.h: Likewise.
13151 * config/i960/i960.h: Likewise.
13152 * config/ia64/ia64.h: Likewise.
13153 * config/ip2k/ip2k.h: Likewise.
13154 * config/m32r/m32r.h: Likewise.
13155 * config/m68k/3b1.h: Likewise.
13156 * config/m68k/3b1g.h: Likewise.
13157 * config/m68k/ccur-GAS.h: Likewise.
13158 * config/m68k/coff.h: Likewise.
13159 * config/m68k/hp2bsd.h: Likewise.
13160 * config/m68k/hp310g.h: Likewise.
13161 * config/m68k/hp320g.h: Likewise.
13162 * config/m68k/hp3bsd.h: Likewise.
13163 * config/m68k/hp3bsd44.h: Likewise.
13164 * config/m68k/linux-aout.h: Likewise.
13165 * config/m68k/m68k-aout.h: Likewise.
13166 * config/m68k/mot3300.h: Likewise.
13167 * config/m68k/netbsd.h: Likewise.
13168 * config/m68k/openbsd.h: Likewise.
13169 * config/m68k/pbb.h: Likewise.
13170 * config/m68k/plexus.h: Likewise.
13171 * config/m68k/sun2.h: Likewise.
13172 * config/m68k/sun3.h: Likewise.
13173 * config/m68k/tower-as.h: Likewise.
13174 * config/m68k/vxm68k.h: Likewise.
13175 * config/m88k/aout-dbx.h: Likewise.
13176 * config/m88k/m88k-aout.h: Likewise.
13177 * config/mcore/mcore-elf.h: Likewise.
13178 * config/mcore/mcore-pe.h: Likewise.
13179 * config/mips/elf.h: Likewise.
13180 * config/mips/elf64.h: Likewise.
13181 * config/mips/iris5gas.h: Likewise.
13182 * config/mips/iris6.h: Likewise.
13183 * config/mips/mips.h: Likewise.
13184 * config/mips/sni-gas.h: Likewise.
13185 * config/mmix/mmix.h: Likewise.
13186 * config/ns32k/netbsd.h: Likewise.
13187 * config/pa/pa64-hpux.h: Likewise.
13188 * config/romp/romp.h: Likewise.
13189 * config/rs6000/sysv4.h: Likewise.
13190 * config/rs6000/xcoff.h: Likewise.
13191 * config/sh/coff.h: Likewise.
13192 * config/sh/elf.h: Likewise.
13193 * config/sparc/linux64.h: Likewise.
13194 * config/sparc/liteelf.h: Likewise.
13195 * config/sparc/netbsd.h: Likewise.
13196 * config/sparc/openbsd.h: Likewise.
13197 * config/sparc/pbd.h: Likewise.
13198 * config/sparc/sp64-elf.h: Likewise.
13199 * config/sparc/sp86x-elf.h: Likewise.
13200 * config/sparc/sparc.h: Likewise.
13201 * config/vax/vax.h: Likewise.
13202 * config/vax/vaxv.h: Likewise.
13203
5e98fba2
DD
132042002-08-29 "Dhananjay R. Deshpande" <dhananjayd@kpit.com>
13205
13206 * h8300.c (shift_alg_hi): Various tweaks to improve performance
13207 of HImode shifts.
13208 (get_shift_alg): Corresponding changes.
13209
43852342
JDA
132102002-08-29 John David Anglin <dave@hiauly1.hia.nrc.ca>
13211
13212 * som.h (ALWAYS_STRIP_DOTDOT): Define to 1.
13213
44bb111a
RH
132142002-08-29 Richard Henderson <rth@redhat.com>
13215
13216 * expr.h (enum block_op_methods): New.
13217 (emit_block_move): Update prototype.
13218 * expr.c (block_move_libcall_safe_for_call_parm): New.
13219 (emit_block_move_via_loop): New.
13220 (emit_block_move): Use them. New argument METHOD.
13221 (emit_push_insn): Always respect the given alignment.
13222 (expand_assignment): Update call to emit_block_move.
13223 (store_expr, store_field, expand_expr): Likewise.
13224 * builtins.c (expand_builtin_apply): Likewise.
13225 (expand_builtin_memcpy, expand_builtin_va_copy): Likewise.
13226 * function.c (expand_function_end): Likewise.
13227 * config/sh/sh.c (sh_initialize_trampoline): Likewise.
13228 * config/sparc/sparc.c (sparc_va_arg): Likewise.
13229 * calls.c (expand_call, emit_library_call_value_1): Likewise.
13230 (save_fixed_argument_area): Use emit_block_move with
13231 BLOCK_OP_CALL_PARM instead of move_by_pieces.
13232 (restore_fixed_argument_area): Likewise.
13233 (store_one_arg): Fix alignment parameter to emit_push_insn.
13234
08b3d104
JDA
132352002-08-29 John David Anglin <dave@hiauly1.hia.nrc.ca>
13236
13237 * install.texi (hppa64-hp-hpux11*): Document installation procedure.
13238
ce4e9970 132392002-08-29 Catherine Moore <clm@redhat.com>
8376061d
CM
13240
13241 * config/v850/v850.h (MULDI3_LIBCALL, UCMPDI2_LIBCALL, CMPDI2_LIBCALL,
13242 NEGDI2_LIBCALL, INIT_TARGET_OPTABS, MASK_STRICT_ALIGN): Define.
13243 (PREDICATE_CODES): Include new predicates.
13244 (RTX_COSTS): Handle UMOD and UDIV. Tune MULT for v850e.
13245 (TARGET_SWITCHES): Add strict-align.
13246 (TARGET_STRICT_ALIGN): New.
2567406a 13247 (MASK_DEFAULT, STRICT_ALIGNMENT): Redefine.
8376061d
CM
13248 * config/v850/t-v850 (MULTILIB_OPTIONS, MULTILIB_DIRNAMES):
13249 Define.
13250 (LIB1ASMFUNCS): Add v850_negdi2, v850_cmpdi2, v850_ucmpdi2,
13251 v850_muldi3.
13252 * config/v850/lib1funcs.asm (L_callt_save_r2_r29, L_return_r2_r29,
13253 L_callt_save_r2_r31, L_return_r2_r31,
13254 L_save_all_interrupt): Change addi to add.
13255 (L_save_interrupt, L_return_interrupt): Rework.
13256 (__return_r31): Correct .size directive.
13257 (mulsi3, divsi3, udivsi3, umodsi3, modsi3): Tune for v850e.
13258 (v850_negdi2, v850_cmpdi2, v850_ucmpdi2, v850_muldi3):
13259 New routines.
13260 * config/v850/v850.c (expand_prologue): Call
13261 gen_callt_save_interrupt, gen_callt_restore_all_interrupt,
13262 gen_callt_return_interrupt and gen_callt_save_all_interrupt.
13263 (reg_or_int9_operand): New predicate.
13264 (reg_or_const_operand): New routine.
13265 * config/v850/v850.md (return_interrupt): Changed from
13266 restore_interrupt.
13267 (callt_save_all_interrupt): Changed from save_all_interrupt_v850e.
13268 (callt_save_interrupt): Change save sequence.
13269 (callt_return_interrupt): New.
13270 (save_interrupt): Don't use runtime function for LONG_CALLS
13271 and TARGET_PROLOG_FUNCTION.
13272 (save_all_interrupt): Likewise.
13273 (mulsi3): Use new predicate.
13274 (moviscc): Disallow some combination of constants.
13275 Fix define_split for sasf insns, so that it will not generate bad
13276 code if operand0 and operand5 are the same.
13277 * config/v850/v850-protos.h: Prototype new predicates.
13278
4977bab6
ZW
132792002-08-29 Zack Weinberg <zack@codesourcery.com>
13280
13281 * config/rs6000/rs6000.c (processor_target_table): Add 405f.
13282 * config/rs6000/rs6000.h (ASM_CPU_SPEC): Likewise.
13283
585e661a
GDR
132842002-08-28 Gabriel Dos Reis <gdr@integrable-solutions.net>
13285
13286 * c-common.c (builtin_define_type_precision): New function.
13287 (cb_register_builtins): Use it. Define __WCHAR_UNSIGNED__ is
13288 wchar_t is unsigned in C++.
13289 * doc/cpp.texi (Common Predefined Macros): Document
13290 __WCHAR_UNSIGNED__, __CHAR_BIT__, __WCHAR_BIT__, __SHRT_BIT__,
13291 __INT_BIT__, __LONG_BIT__, __LONG_LONG_BIT__, __FLOAT_BIT__,
13292 __DOUBLE_BIT__, __LONG_DOUBLE_BIT__.
13293
bd8f9aec
SP
132942002-08-28 Sylvain Pion <pion@cs.nyu.edu>
13295
13296 * doc/invoke.texi (-Wreorder): Remove remaining pieces from the generic
13297 section. Mention that it is enabled by -Wall.
13298 (-Wall): Mention that there can be language-specific warnings as well.
13299 (-Wctor-dtor-privacy): Mention that it is enabled by default.
13300 (-Wnon-virtual-dtor): Mention that it is enabled by -Wall.
13301
58ab7171
R
13302Wed Aug 28 15:35:17 2002 J"orn Rennecke <joern.rennecke@superh.com>
13303
13304 * sh.c (calc_live_regs): Save FPSCR_REG in an interrupt handler
13305 if it is ever live.
13306
13307 * sh.c (sh_handle_interrupt_handler_attribute): Reject interrupt_handler
13308 attribute for SHCOMPACT.
13309
13310 * sh.h (OVERRIDE_OPTIONS): If align_function isn't set, set it
13311 appropriately.
13312 (FUNCTION_BOUNDARY): Specify only the minimum alignment required
13313 by the ABI.
13314
13315 * sh.h (SH5_WOULD_BE_PARTIAL_NREGS): Also handle TImode case.
13316
27f4b67e
JT
133172002-08-28 Jason Thorpe <thorpej@wasabisystems.com>
13318
13319 * config.gcc (mips*-*-netbsd*): Set target_cpu_default to
13320 "MASK_GAS|MASK_ABICALLS".
13321 * config/mips/netbsd.h (TARGET_ENDIAN_DEFAULT)
13322 (TARGET_DEFAULT): Remove.
13323 (MACHINE_TYPE): Undefine before defining.
13324 (DBX_DEBUGGING_INFO, PREFERRED_DEBUGGING_TYPE): Remove.
13325
eca7f13c
MM
133262002-08-27 Mark Mitchell <mark@codesourcery.com>
13327
13328 * c-common.c (warn_abi): New variable.
13329 * c-common.h (warn_abi): Likewise.
13330 * c-opts.c (COMMAND_LINE_OPTIONS): Add -Wabi.
13331 (c_common_decode_option): Handle it.
7ee425e4 13332 * doc/invoke.texi: Document -Wabi.
2567406a 13333
ece4ce85
NP
13334Tue Aug 27 23:03:52 2002 Nicola Pero <n.pero@mi.flashnet.it>
13335
13336 * c-common.c (warn_undeclared_selector): New variable.
13337 * c-common.h (warn_undeclared_selector): Idem.
13338 * c-opts.c (c_common_decode_option): Set warn_undeclared_selector
13339 to on when -Wundeclared-selector is found.
13340 (COMMAND_LINE_OPTIONS): Added -Wundeclared-selector.
13341 * objc/objc-act.c (build_selector_expr): If
13342 warn_undeclared_selector is set, check that the selector has
13343 already been defined, and emit a warning if not.
13344
b4378319 133452002-08-27 Nick Clifton <nickc@redhat.com>
54c93c30
AE
13346 Catherine Moore <clm@redhat.com>
13347 Jim Wilson <wilson@cygnus.com>
13348
13349 * config.gcc: Add v850e-*-* target.
13350 Add --with-cpu= support for v850.
13351 * config/v850/lib1funcs.asm: Add v850e callt functions.
13352 * config/v850/v850.h: Add support for v850e target.
13353 * config/v850/v850.c: Add functions to support v850e target.
13354 * config/v850/v850-protos.h: Add prototypes for new functions in v850.c.
13355 * config/v850/v850.md: Add patterns for v850e instructions.
13356 * doc/invoke.texi: Document new v850e command line switches.
b4378319 13357
ef261fee
R
13358Tue Aug 27 18:30:47 2002 J"orn Rennecke <joern.rennecke@superh.com>
13359 Aldy Hernandez <aldyh at redhat dot com>
13360
13361 * doc/tm.texi: Applied numerous fixes to the automaton based
13362 scheduler descrition.
13363
c60ee6f5
JH
13364Tue Aug 27 19:51:05 CEST 2002 Jan Hubicka <jh@suse.cz>
13365
13366 * i386.c (classify_argument): Handle variable sized objects.
13367
1985ef90
JH
13368Tue Aug 27 19:18:16 CEST 2002 Jan Hubicka <jh@suse.cz>
13369
13370 * i386.c (ix86_expand_int_movcc): Fix RTL sharing problem
13371
7acc97e0
JH
13372Tue Aug 27 18:01:45 CEST 2002 Jan Hubicka <jh@suse.cz>
13373
13374 * libgcc2.c (__bb_exit_func): Properly write the summarized statistics.
13375
23327dae
JH
13376Tue Aug 27 18:00:11 CEST 2002 Jan Hubicka <jh@suse.cz>
13377
13378 * i386.c (classify_argument): Properly compute word size of the analyzed object.
13379
c49439f1
R
13380Tue Aug 27 14:39:09 2002 J"orn Rennecke <joern.rennecke@superh.com>
13381
13382 * sh.md (attribute type): Add types mt_group, fload, pcfload, fpul_gp,
13383 mac_gp ftrc_s and cwb. Add / Adjust definitions in individual insn
13384 accordingly.
13385 (attribute insn_class): Provide default definitions based on type.
13386 Remove all insn-specific settings.
13387 (various function units): Remove old SH4 scheduling.
13388 (branch_zero, dfp_comp, late_fp_use, any_fp_comp, any_int_load):
13389 New attributes. Set them where appropriate.
13390 (cpu unit FS): Don't define / use.
13391 (F3, load_store): New cpu units.
13392 (F01): New reservation.
13393 (all insn_reservations): Make dependent on sh4 pipeline model.
13394 Fix latencies.
13395 (nil, reg_mov, freg_mov, sh4_fpul_gp, sh4_call): New insn_reservations.
13396 (sh4_mac_gp, fp_arith_ftrc, arith3, arith3b): Likewise.
13397 (mt insn_reservation): Use type mt_group.
13398 (insn_reservation load_store): Split into sh4_load, sh4_load_si,
13399 sh4_fload and sh4_store.
13400 (insn_reservation branch_zero and branch): Replace with sh4_branch.
13401 (insn_reservation branch_far): Replace with sh4_return.
13402 (insn_reservation return_from_exp): Rename to:
13403 (sh4_return_from_exp). Change to be just d_lock*5.
13404 (insn_reservation lds_to_pr): Rename to:
13405 (sh4_lds_to_pr). Change to be just d_lock*2.
13406 (insn_reservation ldsmem_to_pr, sts_from_pr): Change to be just
13407 d_lock*2.
13408 (insn_reservation prload_mem): Rename to:
13409 (sh4_prstore_mem). Change to d_lock*2,nothing,memory.
13410 (insn_reservation fpscr_store): Rename to:
13411 (fpscr_load). Change to d_lock,nothing,F1*3.
13412 (insn_reservation fpscr_store_mem): Rename to:
13413 (fpscr_load_mem). Change to d_lock,nothing,(F1+memory),F1*2.
13414 (insn_reservation multi): Change to
13415 d_lock,(d_lock+f1_1),(f1_1|f1_2)*3,F2.
13416 (insn_reservation fp_arith): Change to issue,F01,F2.
13417 (insn_reservation fp_div: Change to issue,F01+F3,F2+F3,F3*7,F1+F3,F2.
13418 (insn_reservation dp_float): Change to issue,F01,F1+F2,F2.
13419 (insn_reservation fp_double_arith): Change to issue,F01,F1+F2,fpu*4,F2.
13420 (insn_reservation fp_double_cmp): Change to
13421 d_lock,(d_lock+F01),F1+F2,F2.
13422 (insn_reservation dp_div): Change to
13423 issue,F01+F3,F1+F2+F3,F2+F3,F3*16,F1+F3,(fpu+F3)*2,F2.
13424 * sh.c (flow_dependent_p, flow_dependent_p_1): New functions.
13425 (sh_adjust_cost, SHcompact): Differentiate between different
13426 kinds of dependencies. Drop factor of ten for superscalar.
13427 Use new instruction types. Add new exception rules.
13428
13429 * sh.md (mulhisi3, umulhisi3: Add a REG_EQUAL note.
13430
13431 * sh.md (mperm_w): Add DONE.
13432
f34fc46e
DE
134332002-08-27 David Edelsohn <edelsohn@gnu.org>
13434
13435 * longlong.h: Import current PowerPC defintion from GMP-4.1.
13436
13437 * config/rs6000/rs6000.h (MIN_UNITS_PER_WORD): Add IN_LIBGCC2 case.
13438
13439 * config/rs6000/linux64.h (ADJUST_FIELD_ALIGN): Undef before define.
13440
dcb44500
R
13441Tue Aug 27 13:53:57 2002 J"orn Rennecke <joern.rennecke@superh.com>
13442
13443 * sh.h (MAX_FIXED_MODE_SIZE): Define.
13444
3ec07554
GDR
134452002-08-27 Gabriel Dos Reis <gdr@soliton.integrable-solutions.net>
13446
13447 * doc/cpp.texi (Common Predefined Macros): Don't mess with table
2567406a 13448 delimiter.
3ec07554 13449
35885eab
GDR
134502002-08-27 Gabriel Dos Reis <gdr@integrable-solutions.net>
13451
13452 * c-common.c (cpp_define_data_format): New function.
13453 (cb_register_builtins): Call it.
13454
13455 * doc/cpp.texi (Common Predefined Macros): Document
13456 __TARGET_BITS_ORDER__, __TARGET_BYTES_ORDER__,
13457 __TARGET_INT_WORDS_ORDER__, __TARGET_FLOAT_WORDS_ORDER__,
13458 __TARGET_FLOAT_FORMAT__, __TARGET_USES_VAX_F_FLOAT__,
13459 __TARGET_USES_VAX_D_FLOAT__, __TARGET_USES_VAX_G_FLOAT__,
13460 __TARGET_USES_VAX_H_FLOAT__.
13461
d632dee9
ZL
134622002-08-26 Ziemowit Laski <zlaski@apple.com>
13463
13464 * objc/objc-act.c (get_super_receiver): If inside a class method
13465 of a category, cast the receiver to 'id' before accessing the 'isa'
13466 field so that <objc/objc-class.h> is not needed. For NeXT runtime.
13467
c3cc6b78
UW
134682002-08-26 Ulrich Weigand <uweigand@de.ibm.com>
13469
2567406a 13470 * config/s390/s390-protos.h (s390_function_prologue,
c3cc6b78
UW
13471 s390_function_epilogue): Remove.
13472 config/s390/s390.c (s390_function_prologue, s390_function_epilogue,
13473 TARGET_ASM_FUNCTION_PROLOGUE, TARGET_ASM_FUNCTION_EPILOGUE): Remove.
13474
13475 config/s390/s390.c (s390_machine_dependent_recorg): New function.
13476 config/s390/s390-protos.h (s390_machine_dependent_reorg): Declare it.
13477 config/s390/s390.h (MACHINE_DEPENDENT_REORG): Call it.
13478 config/s390/s390.c (s390_split_branches, s390_chunkify_pool): Adapt
13479 to being called from MACHINE_DEPENDENT_REORG. Update regs_ever_live.
13480
2567406a 13481 config/s390/s390.c (s390_frame_info): Inline save_fprs_p. Always
c3cc6b78
UW
13482 assume BASE_REGISTER and RETURN_REGNUM need to be saved.
13483 (s390_emit_prologue): Assume RETURN_REGNUM to be saved iff
13484 function is not a leaf function. Use save_gprs and restore_gprs.
13485 (s390_emit_epilogue): Likewise.
13486 (save_gprs, restore_gprs): New functions.
13487 (struct s390_frame): Remove return_reg_saved_p member.
13488 (save_fprs_p): Remove.
13489 (s390_optimize_prolog): New function.
13490 (s390_legitimate_reload_constant): Remove now unnecessary check.
13491
13492 (s390_function_count): Remove.
13493 (s390_output_symbolic_const): Replace s390_function_count by
13494 current_function_funcdef_no.
13495 (s390_output_constant_pool): Likewise.
13496
13497 (legitimize_pic_address): Use regs_ever_live to track PIC register
13498 instead of current_function_uses_pic_offset_table.
13499 (s390_emit_prologue): Likewise.
13500 config/s390/s390.md ("call", "call_value"): Likewise.
13501
3f662186
NB
135022002-08-26 Neil Booth <neil@daikokuya.co.uk>
13503
13504 * c-opts.c (find_opt): Don't complain about wrong languages
13505 here. Return exact matches even for wrong language.
13506 (c_common_decode_option): Complain about wrong languages
13507 here.
13508
b6128b8c
SH
135092002-08-24 Stuart Hastings <stuart@apple.com>
13510
13511 * function.h (struct function): Add flag
13512 all_throwers_are_sibcalls.
13513 * except.c (set_nothrow_function_flags): Replaces
13514 nothrow_function_p. Set new flag.
13515 * except.h (set_nothrow_function_flags): Replaces
13516 nothrow_function_p.
13517 * dwarf2out.c (struct dw_fde_struct): Add flag
13518 all_throwers_are_sibcalls.
13519 (output_call_frame_info): Test it.
13520 (dwarf2out_begin_prologue) Propagate it from cfun to
13521 dw_fde_struct.
13522 * toplev.c (rest_of_compilation): Update calls to
13523 nothrow_function_p.
13524
280cf02a
ZW
135252002-08-23 Zack Weinberg <zack@codesourcery.com>
13526
13527 * ggc-page.c (compute_inverse): Short circuit calculation for
13528 object sizes larger than half a page.
13529
c6664446
DE
135302002-08-23 David Edelsohn <edelsohn@gnu.org>
13531
13532 * config/rs6000/rs6000.c (rs6000_elf_select_section): Treat
13533 DEFAULT_ABI == ABI_AIX like PIC. Test PIC & reloc for readonly
13534 default.
13535 (rs6000_elf_unique_section): Likewise.
13536
da57d233
KG
135372002-08-23 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
13538
13539 * ns32k.c (ns32k_globalize_label): Delete.
13540 * ns32k.h (ASM_OUTPUT_LABEL, TARGET_ASM_GLOBALIZE_LABEL): Delete.
13541
56a7189a
AM
135422002-08-23 Alan Modra <amodra@bigpond.net.au>
13543
13544 * config/rs6000/rs6000.c (output_mi_thunk): Don't determine insns
13545 for loading delta with num_insns_constant_wide. Calculate
13546 delta_low, delta_high without using a conditional.
13547
d65b1d77
JM
135482002-08-22 Jason Merrill <jason@redhat.com>
13549
13550 * c-common.h (RETURN_STMT_EXPR): Rename from RETURN_EXPR.
13551 * c-common.def: Adjust.
13552 * c-dump.c (c_dump_tree): Adjust.
13553 * c-semantics.c (genrtl_return_stmt): Adjust.
13554 * c-pretty-print.c (pp_c_statement): Adjust.
13555 * tree-inline.c (copy_body_r): Adjust.
13556
8537ed68
ZW
135572002-08-22 Zack Weinberg <zack@codesourcery.com>
13558
13559 * ggc-page.c: Avoid division in ggc_set_mark.
13560 (DIV_MULT, DIV_SHIFT, OFFSET_TO_BIT, inverse_table,
13561 compute_inverse): New.
13562 (ggc_set_mark, ggc_marked_p): Use OFFSET_TO_BIT.
13563 (init_ggc): Initialize inverse_table.
13564
8567c70f
TT
135652002-08-22 Tom Tromey <tromey@redhat.com>
13566
13567 * doc/install.texi (Configuration): Document --datadir.
13568
fde59d4b
AO
135692002-08-22 Alexandre Oliva <aoliva@redhat.com>
13570
13571 * Makefile.in ($(BUILD_PREFIX_1)varray.o): Depend on $(GGC_H).
13572
44ddc79a
HPN
135732002-08-22 Hans-Peter Nilsson <hp@bitrange.com>
13574
13575 * gengtype-lex.l (ID): Allow underscore as first character.
13576
b275d088
DE
135772002-08-21 David Edelsohn <edelsohn@gnu.org>
13578
13579 * config/rs6000/rs6000.c (rs6000_xcoff_asm_globalize_label): New
13580 function.
13581 (rs6000_xcoff_asm_named_section): Rename.
13582 * config/rs6000/xcoff.h (TARGET_ASM_GLOBALIZE_LABEL): Define.
13583
57ce46bb
TT
135842002-08-21 Tom Tromey <tromey@redhat.com>
13585
13586 For PR java/6005 and PR java/7611:
13587 * fold-const.c (fold_truthop): Use can_use_bit_fields_p.
13588 (fold): Likewise.
13589 * langhooks.c (lhd_can_use_bit_fields_p): New function.
13590 * langhooks-def.h (lhd_can_use_bit_fields_p): Declare.
13591 (LANG_HOOKS_CAN_USE_BIT_FIELDS_P): New define.
13592 (LANG_HOOKS_INITIALIZER): Use it.
13593 * langhooks.h (struct lang_hooks) [can_use_bit_fields_p]: New
13594 field.
13595
27d30956
SS
135962002-08-21 Stan Shebs <shebs@apple.com>
13597
13598 * tree.c (finish_vector_type): Fix a typo in a comment.
13599 * Makefile.in: Fix "the the" stutters in comments.
13600 * genautomata.c: Ditto.
13601 * ifcvt.c: Ditto.
13602 * regrename.c: Ditto.
13603 * config/alpha/alpha.c: Ditto.
13604 * config/alpha/vms-crt0-64.c: Ditto.
13605 * config/alpha/vms-crt0.c: Ditto.
13606 * config/alpha/vms-psxcrt0-64.c: Ditto.
13607 * config/alpha/vms-psxcrt0.c: Ditto.
13608 * config/d30v/d30v.h: Ditto.
13609 * config/fr30/fr30.h: Ditto.
13610 * config/rs6000/rs6000.c: Ditto.
13611 * config/stormy16/stormy16.h: Ditto.
13612 * doc/md.texi: Ditto.
8537ed68 13613
d873d827
JDA
136142002-08-21 John David Anglin <dave@hiauly1.hia.nrc.ca>
13615
13616 * cppinit.c (remove_dup_nonsys_dirs): Fix warning and return value.
13617
b462d4ab
JM
136182002-08-21 Joseph S. Myers <jsm@polyomino.org.uk>
13619
13620 * c-decl.c (grokdeclarator): Make invalid combinations with long,
13621 short, signed or unsigned into hard errors. Fixes PR c/4319.
13622 Also make duplicate modifiers such as "short short" into hard
13623 errors.
13624
b65d23aa 136252002-08-21 Andrew Pinski <pinskia@physics.uc.edu>
8537ed68 13626 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
b65d23aa
AP
13627
13628 * doc/tm.texi (TARGET_ASM_GLOBALIZE_LABEL): Move '@end deftypefn'
13629 to the actual end. Add '@end table' and '@table @code'.
8537ed68 13630
3823f0b2
GK
136312002-08-20 Geoffrey Keating <geoffk@redhat.com>
13632
8d25d915
GK
13633 * doc/tm.texi (Label Output): Add missing '@end deftypefn'.
13634
3823f0b2
GK
13635 * unroll.c (biv_total_increment): Don't try to compute the total
13636 increment for FP BIVs.
13637
5eb99654
KG
136382002-08-20 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
13639
13640 * alpha.c (TARGET_ASM_GLOBALIZE_LABEL): Define for unicosmk.
13641 * alpha/elf.h (ASM_OUTPUT_EXTERNAL_LIBCALL,
13642 ASM_OUTPUT_ALIGNED_BSS): Use target hook.
13643 * alpha/osf.h (ASM_OUTPUT_WEAK_ALIAS): Likewise.
13644 * alpha/unicosmk.h (ASM_GLOBALIZE_LABEL): Delete.
13645 * arm/aof.h (ASM_GLOBALIZE_LABEL): Likewise.
13646 (GLOBAL_ASM_OP): Define.
13647 * arm.c (aof_globalize_label): New function.
13648 (TARGET_ASM_GLOBALIZE_LABEL): Define for AOF.
13649 * arm/unknown-elf.h (ASM_OUTPUT_ALIGNED_BSS): Use target hook.
13650 * c4x.c (c4x_globalize_label): New function.
13651 (TARGET_ASM_GLOBALIZE_LABEL): Define for c4x.
13652 * c4x.h (ASM_GLOBALIZE_LABEL): Delete.
13653 (GLOBAL_ASM_OP): Define.
13654 * cris/aout.h (ASM_OUTPUT_EXTERNAL_LIBCALL): Use target hook.
13655 * darwin-protos.h (darwin_globalize_label): Declare.
13656 * darwin.c (darwin_globalize_label): New function.
13657 * darwin.h (ASM_DECLARE_CLASS_REFERENCE): Use target hook.
13658 (ASM_GLOBALIZE_LABEL): Delete.
13659 (GLOBAL_ASM_OP, TARGET_ASM_GLOBALIZE_LABEL): Define.
13660 * dsp16xx.c (asm_output_common): Use target hook.
13661 * elfos.h (ASM_OUTPUT_EXTERNAL_LIBCALL): Likewise.
13662 * frv.h (ASM_GLOBALIZE_LABEL): Delete.
13663 (GLOBAL_ASM_OP): Define.
13664 * i370.c (i370_globalize_label): New function.
13665 (TARGET_ASM_GLOBALIZE_LABEL): Define for i370.
13666 * i370.h (ASM_GLOBALIZE_LABEL): Delete.
13667 * i386.c (ix86_asm_file_end): Use target hook.
13668 * i386/sco5.h (ASM_GLOBALIZE_LABEL): Don't undef.
13669 (ASM_OUTPUT_EXTERNAL_LIBCALL): Use target hook.
13670 * ia64.c (ia64_asm_output_external): Likewise.
13671 * ia64/sysv4.h: Update comment.
13672 * m32r.h (ASM_OUTPUT_ALIGNED_BSS): Use target hook.
13673 * mips/elf.h (ASM_OUTPUT_ALIGNED_BSS): Likewise.
13674 * mips/iris5.h (ASM_OUTPUT_WEAK_ALIAS): Use target hook.
13675 * mips/linux.h (ASM_OUTPUT_ALIGNED_BSS): Likewise.
13676 * mips.h (ASM_OUTPUT_ALIGNED_DECL_COMMON): Use target hook.
13677 * mmix-protos.h (mmix_asm_globalize_label): Delete.
13678 * mmix.c (mmix_asm_globalize_label): Likewise.
13679 * mmix.h (ASM_GLOBALIZE_LABEL): Likewise.
13680 (GLOBAL_ASM_OP): Define.
13681 * ns32k.c (ns32k_globalize_label): New function.
13682 * ns32k.h (TARGET_ASM_GLOBALIZE_LABEL): Define for ns32k.
13683 (ASM_GLOBALIZE_LABEL): Delete.
13684 * pa/pa-linux.h (ASM_GLOBALIZE_LABEL): Don't undef.
13685 (TARGET_ASM_GLOBALIZE_LABEL): Undefine.
13686 * pa.c (pa_globalize_label): New function.
13687 * pa.h (ASM_GLOBALIZE_LABEL): Delete.
13688 (TARGET_ASM_GLOBALIZE_LABEL): Define for pa.
13689 * rs6000/darwin.h (ASM_GLOBALIZE_LABEL): Delete.
13690 (GLOBAL_ASM_OP): Define.
13691 (TARGET_ASM_GLOBALIZE_LABEL): Undef.
13692 * rs6000/sysv4.h (ASM_OUTPUT_ALIGNED_BSS): Use target hook.
13693 * rs6000/xcoff.h (ASM_GLOBALIZE_LABEL): Delete.
13694 (GLOBAL_ASM_OP): Define.
13695 * v850.c (v850_output_aligned_bss): Use target hook.
13696 * vax.c (vms_globalize_label): New function.
13697 (TARGET_ASM_GLOBALIZE_LABEL): Define for vms.
13698 * vax/vms.h (ASM_GLOBALIZE_LABEL): Delete.
13699 (GLOBAL_ASM_OP): Define.
13700 * defaults.h (ASM_GLOBALIZE_LABEL): Delete.
13701 * doc/tm.texi: Update docs.
13702 * dwarf2out.c (default_eh_frame_section, output_die_symbol): Use
13703 target hook.
13704 * final.c (output_alternate_entry_point): Likewise.
13705 * hooks.c (hook_FILEptr_constcharptr_void): New function.
13706 * hooks.h (hook_FILEptr_constcharptr_void): Declare.
13707 * output.h (assemble_global): Delete.
13708 (default_globalize_label): Declare.
13709 * system.h (ASM_GLOBALIZE_LABEL): Poison.
13710 * target-def.h (TARGET_ASM_GLOBALIZE_LABEL): Define.
13711 (TARGET_ASM_OUT): Add TARGET_ASM_GLOBALIZE_LABEL.
13712 * target.h (gcc_target): Add globalize_label member.
13713 * varasm.c (asm_output_bss, asm_output_aligned_bss,
13714 globalize_decl): Use target hook.
13715 (assemble_global): Delete.
13716 (default_globalize_label): New function.
13717
f8f28a75
KG
137182002-08-20 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
13719
13720 * dsp16xx.h (dsp16xx_umulhi3_libcall): Delete.
13721
92b5aacd
DP
137222002-08-20 Devang Patel <dpatel@apple.com>
13723 * tree.c (get_qualified_type): Add TYPE_CONTEXT check.
8537ed68 13724
761c70aa
KG
137252002-08-20 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
13726
13727 * arc.c (output_shift): Use stdio instead of asm_fprintf.
13728 * arm.c (thumb_output_function_prologue): Likewise.
13729 * avr.c (print_operand): Likewise.
13730 * c4x.c (c4x_print_operand): Likewise.
13731 * c4x.h (ASM_OUTPUT_INTERNAL_LABEL, TRAMPOLINE_TEMPLATE,
13732 ASM_OUTPUT_REG_PUSH, ASM_OUTPUT_REG_POP): Likewise.
13733 * cris.c (cris_target_asm_function_prologue,
13734 cris_asm_output_mi_thunk): Likewise.
13735 * h8300.c (print_operand): Likewise.
13736 * h8300.h (ASM_OUTPUT_ADDR_VEC_ELT): Likewise.
13737 * ip2k.c (print_operand): Likewise. Fix format specifier.
13738 * m68hc11.c (asm_print_register, print_operand,
13739 print_operand_address): Use stdio instead of asm_fprintf.
13740 (print_operand_address): Fix format specifier.
13741 * m68hc11.h (FUNCTION_PROFILER, ASM_OUTPUT_ADDR_DIFF_ELT,
13742 ASM_OUTPUT_ADDR_VEC_ELT, ASM_OUTPUT_ALIGN): Use stdio instead of
13743 asm_fprintf.
13744 * m68k/amix.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
13745 * m68k/atari.h (ASM_OUTPUT_INTERNAL_LABEL): Likewise.
13746 * m68k.c (m68k_output_function_prologue,
13747 m68k_output_function_epilogue, print_operand): Likewise.
13748 * mmix.c (mmix_asm_output_mi_thunk, mmix_asm_weaken_label):
13749 Likewise. Fix format specifier.
13750 * mn10200.h (ASM_OUTPUT_ADDR_VEC_ELT): Likewise.
13751 * mn10300.h (ASM_OUTPUT_ADDR_VEC_ELT): Likewise.
13752 * v850.h (ASM_OUTPUT_ADDR_VEC_ELT): Likewise.
13753
5ce6f47b
EC
137542002-08-15 Eric Christopher <echristo@redhat.com>
13755 Jeff Knaggs <jknaggs@redhat.com>
13756
13757 * config.gcc (mipsisa64sr71k-elf): New target.
13758 * config/mips/sr71k.md: New file.
13759 * config/mips/mips.md: Use it.
13760 (rot*): Add sr71k specifics.
13761 * config/mips/t-sr71k: New file.
13762 * config/mips/mips.h (sr71k): New cpu.
13763 (TARGET_SR71K): Use it.
13764 (TUNE_SR71K): Ditto.
13765 (GENERATE_BRANCHLIKELY): Ditto.
13766 (ISA_HAS_MULHI, ISA_HAS_MULS, ISA_HAS_MSAC, ISA_HAS_MACC,
13767 ISA_HAS_ROTR_SIISA_HAS_ROTR_DI): Ditto.
13768 * config/mips/mips.c (sr71k): New cpu.
13769 (mips_use_dfa_pipeline_interface): Use.
13770
137712002-08-15 Eric Christopher <echristo@redhat.com>
8537ed68 13772 Richard Sandiford <rsandifo@redhat.com>
5ce6f47b
EC
13773 Aldy Hernandez <aldyh@redhat.com>
13774 Graham Stott <grahams@redhat.com>
13775 Michael Meissner <meissner@redhat.com>
13776 Gavin Romig-Koch <gavin@redhat.com>
13777 Ken Raeburn <raeburn@cygnus.com>
13778 Alexandre Oliva <aoliva@redhat.com>
13779
13780 * config.gcc (mips64vr-elf): New target.
13781 * config/mips/5400.md: New file.
13782 * config/mips/5500.md: Ditto.
13783 * config/mips/mips.md: Use them.
13784 (frsqrt): New.
13785 * config/mips/mips.c (vr4111, vr4121, vr4320, vr5400, vr5500): New
13786 cpus.
13787 (mips_issue_rate): Use them.
13788 (mips_use_dfa_pipeline_interface): New function. Use for 5400 and 5500.
13789 (TARGET_SCHEDUSE_DFA_PIPELINE_INTERFACE): Define. Use above.
13790 * config/mips/mips.h (vr4111, vr4121, vr4320, vr5400, vr5500): New
13791 cpus.
13792 (TARGET_MIPSx): Use them.
13793 (TUNE_MIPSx): Ditto.
13794 (GETNATE_MULT3_SI): Ditto.
13795 (ISA_HAS_BRANCHLIKELY): Ditto.
13796 (ISA_HAS_CONDMOVE): Ditto.
13797 (ISA_HAS_NMADD_NMSUB): Ditto.
13798 (ISA_HAS_MULHI): New. Ditto.
13799 (ISA_HAS_MULS): Ditto.
13800 (ISA_HAS_MSAC): Ditto.
13801 (ISA_HAS_MACC): Ditto.
13802 (ISA_HAS_ROTR_SI): Ditto.
13803 (ISA_HAS_ROTR_DI): Ditto.
13804 (RTX_COSTS): Use.
13805
48209ce5
JDA
138062002-08-20 John David Anglin <dave@hiauly1.hia.nrc.ca>
13807
13808 * cppinit.c (remove_dup_dir): Add head_ptr argument to handle removal
13809 at head.
13810 (remove_dup_nonsys_dirs): New function.
13811 (remove_dup_dirs): Change argument head to head_ptr. Remove warnings.
13812 (merge_include_chains): Remove non-system include directories from
13813 quote and bracket include chains when they duplicate equivalent system
13814 directories.
13815 * doc/cpp.texi (-I): Update.
8537ed68
ZW
13816 * doc/cppopts.texi (-I): Update.
13817 * doc/install.texi (--with-local-prefix): Further document usage of
48209ce5
JDA
13818 this option.
13819 * doc/invoke.texi (-I): Update.
13820
4ca79136
RH
138212002-08-20 Richard Henderson <rth@redhat.com>
13822
13823 * expr.c (TARGET_MEM_FUNCTIONS): Transform to boolean.
13824 (emit_block_move): Split out subroutines.
13825 (emit_block_move_via_movstr): New.
13826 (emit_block_move_via_libcall): New. Emit bcopy via normal call also.
13827 (emit_block_move_libcall_fn): New. Construct function prototype for
13828 bcopy as well.
13829 (clear_storage): Split out subroutines.
13830 (clear_storage_via_clrstr): New.
13831 (clear_storage_via_libcall): New. Emit bzero as a normal call also.
13832 (clear_storage_libcall_fn): New. Construct function prototype for
13833 bzero as well.
13834 (emit_push_insn): Use emit_block_move.
13835 (expand_assignment): Booleanize TARGET_MEM_FUNCTIONS.
13836 (store_constructor): Likewise.
13837
9f05cef3
ZL
138382002-08-19 Ziemowit Laski <zlaski@apple.com>
13839
13840 * objc/objc-act.c (building_objc_message_expr): Rename to
13841 current_objc_message_selector.
13842
1bd5981b
ZL
138432002-08-19 Ziemowit Laski <zlaski@apple.com>
13844
13845 * objc/objc-act.c (build_ivar_chain): Remove.
13846 (objc_copy_list): Likewise.
13847 (get_class_ivars): Inline call to removed build_ivar_chain
13848 function. Save off a clean copy of ivars in the CLASS_OWN_IVARS
13849 slot; use that slot (rather than CLASS_IVARS) when accessing
13850 ivars for base classes. Call copy_list and chainon instead of
13851 objc_copy_list.
13852 (build_private_template): Call get_class_ivars instead of
13853 build_ivar_chain.
13854 (start_class): Allocate room for the CLASS_OWN_IVARS slot.
5ce6f47b 13855 (continue_class): Call get_class_ivars instead of
1bd5981b
ZL
13856 build_ivar_chain.
13857 (encode_field_decl): Check for DECL_BIT_FIELD_TYPE instead
13858 of DECL_BIT_FIELD (which may have been cleared).
13859 * objc/objc-act.h (CLASS_OWN_IVARS): New accessor macro.
13860
2bf087c0
KG
138612002-08-19 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
13862
13863 * genautomata.c (output_translate_vect, output_state_ainsn_table,
13864 output_min_issue_delay_table): Mark variable with ATTRIBUTE_UNUSED
13865 in output file.
13866 (output_internal_min_issue_delay_func): Initialize variable in
13867 output file.
13868
3fcd079e
AO
138692002-08-19 Alexandre Oliva <aoliva@redhat.com>
13870
13871 * Makefile.in (GCC_FOR_TARGET): Prepend STAGE_CC_WRAPPER.
13872 (stage2_build, stage3_build, stage4_build): Likewise, to CC.
13873
71012d97
GK
138742002-08-19 Geoffrey Keating <geoffk@redhat.com>
13875 Steve Ellcey <sje@cup.hp.com>
13876
13877 * machmode.h (SCALAR_INT_MODE_P): New macro to test for
13878 scaler integer mode (MODE_INT or MODE_PARTIAL_INT).
13879 * explow.c (trunc_int_for_mode): Abort when the mode is not
13880 a scaler integer mode.
13881 * combine.c (expand_compound_operation): Don't expand Vector
13882 or Complex modes into shifts.
13883 (expand_field_assignment): Don't do bitwise arithmatic and
13884 shifts on Vector or Complex modes.
13885 (simplify_comparison): Don't call trunc_int_for_mode
13886 for VOIDmode.
13887 * recog.c (general_operand): Likewise.
13888 (immediate_operand): Likewise.
13889 (nonmemory_operand): Likewise.
13890
af8cb5c5
DE
138912002-08-19 David Edelsohn <edelsohn@gnu.org>
13892
13893 * config/rs6000/rs6000.c (rs6000_emit_set_const): Inline
13894 multi-instruction SImode constant. Add REG_EQUAL note.
13895 * config/rs6000/rs6000.md (movsi splitter): Use
5ce6f47b 13896 rs6000_emit_set_const.
af8cb5c5 13897
9bc146b3
KG
138982002-08-19 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
13899
13900 * tree-inline.c (initialize_inlined_parameters): Wrap variable in
13901 the macro test controlling its use.
13902
66df2ac2
L
139032002-08-18 H.J. Lu (hjl@gnu.org)
13904
13905 * config.gcc (*-*-linux*): Set extra_parts="crtbegin.o
13906 crtbeginS.o crtbeginT.o crtend.o crtendS.o", gas=yes and
13907 gnu_ld=yes.
13908 (alpha*-*-linux*, cris-*-linux*, i370-*-linux*,
13909 i[34567]86-*-linux*, x86_64-*-linux*, mips*-*-linux*,
13910 s390-*-linux*, s390x-*-linux*, sparc-*-linux*, sparc64-*-linux*,
13911 xtensa-*-linux*): Remove setting extra_parts, gas, and gnu_ld
13912 here.
13913 (cris-*-linux*): Remove setting thread_file here.
13914
463f1b2b
NB
139152002-08-18 Neil Booth <neil@daikokuya.co.uk>
13916
13917 PR preprocessor/7602
13918 * cppinit.c (path_include): Treat the system environment
13919 variables as being cxx_aware.
13920
2984fe64
JM
139212002-08-17 Joseph S. Myers <jsm@polyomino.org.uk>
13922
13923 * c-decl.c (flexible_array_type_p): New function.
13924 (grokdeclarator, finish_struct): Use it.
13925 * doc/extend.texi: Document constraints on use of structures with
13926 flexible array members.
13927
fded6d78
RS
139282002-08-17 Richard Sandiford <rsandifo@redhat.com>
13929
13930 * config/mips/t-coff, config/mips/t-elf, config/mips/t-isa3264,
13931 config/mips/t-r3900 (MULTILIB_MATCHES): Define.
13932 * config/mips/mips.h (ASM_SPEC): Use %(endian_spec).
13933
8aa5074e
SS
139342002-08-16 Stan Shebs <shebs@apple.com>
13935
13936 * c-common.c (cb_register_builds): Define __NEXT_RUNTIME__
13937 for ObjC with -fnext-runtime.
13938 * doc/cpp.texi: Document it.
13939
f97a5bda
JJ
139402002-08-16 Janis Johnson <janis187@us.ibm.com>
13941
13942 * doc/install.texi (Final installation): Replace links to individual
13943 build status pages with a link to a common page that lists them all.
13944
d3075b6c
SP
139452002-08-16 Sylvain Pion <pion@cs.nyu.edu>
13946
13947 * doc/invoke.texi: Fix typo.
13948
fdf68669
DE
139492002-08-16 David Edelsohn <edelsohn@gnu.org>
13950
13951 * doc/install.texi (*-ibm-aix*): Explain AIX shared object versioning.
13952
139532002-08-16 Andrew Haley <aph@redhat.com>
d436bff8
AH
13954
13955 * tree-inline.c: Add includes for Java inliner.
13956 (remap_decl): Don't handle anonymous types for Java.
13957 (remap_block): Add handling for Java trees.
13958 (copy_scope_stmt): Conditionalize for non-Java use only.
13959 (copy_body_r): Handle Java trees. Add handling for
13960 LABELED_BLOCK_EXPR, EXIT_BLOCK_EXPR, Java blocks.
13961 (initialize_inlined_parameters): Handle Java trees.
13962 (declare_return_variable): Likewise.
13963 (expand_call_inline): Handle Java trees.
13964 (walk_tree): Likewise.
13965 (copy_tree_r): Don't handle SCOPE_STMTs for Java.
13966 (add_stmt_to_compound): New function.
13967
204250d2
RH
139682002-08-15 Richard Henderson <rth@redhat.com>
13969
13970 * Makefile.in (LOOSE_WARN): Remove -fno-common.
13971 (NOCOMMON_FLAG): New substitution point.
13972 (GCC_WARN_CFLAGS): Include it.
13973 * configure.in (ac_checking): Set nocommon_flag.
13974 (nocommon_flag): New substitution point.
13975
25587e40
AO
139762002-08-15 Alexandre Oliva <aoliva@redhat.com>
13977
13978 * c-tree.h (skip_evaluation): Move declaration...
13979 * c-common.h: ... here.
13980 * c-typeck.c (build_external_ref): Don't assemble_external nor
13981 mark a tree as used if skip_evaluation is set.
13982 * c-parse.in (typeof): New non-terminal to set skip_evaluation
13983 around TYPEOF.
13984 (typespec_nonreserved_nonattr): Use it.
13985
702ada3d
DR
139862002-08-15 Douglas B Rupp <rupp@gnat.com>
13987
13988 * dbxout.c (dbx_debug_hooks): Update end_prologue, end_epilogue.
13989 (xcoff_debug_hooks): Update end_prologue.
13990 * debug.c (do_nothing_debug_hooks): Update end_prologue, end_epilogue.
13991 * debug.h (end_prologue): Add file arg.
13992 (end_epilogue): Add line and file args.
13993 (dwarf2out_end_epilogue): Add line and file args.
13994 (vmsdbgout_after_prologue): Remove.
13995 * dwarf2out.c (dwarf2out_end_epilogue): Add line and file args.
13996 (dwarf2_debug_hooks): Update end_prologue.
13997 * dwarfout.c (dwarfout_end_epilogue): Add line and file args.
13998 (dwarfout_end_prologue): Add file arg.
13999 * final.c (vmsdbgout_after_prologue): Remove
14000 (final_end_function): Update end_epilogue call.
14001 (final_scan_insn): Update end_prologue call.
14002 * sdbout.c (sdbout_end_epilogue): Add line and file args.
14003 (sdbout_end_prologue): Add file arg.
14004 (sdb_debug_hooks): Update end_prologue.
14005 (sdb_begin_prologue): Update sdbout_end_prologue call.
14006 * vmsdbgout.c (vmsdbg_debug_hooks): Add vmsdbgout_end_prologue,
14007 vmsdbgout_end_function.
14008 (vmsdbgout_end_prologue): New function renamed from
14009 vmsdbgout_after_prologue. Call vmsdbgout_source_line.
14010 (vmsdbgout_end_function): New function.
14011 (vmsdbgout_end_epilogue): Add line and file args. Call
14012 vmsdbgout_source_line.
14013 (write_pclines): Write only valid line numbers.
14014 (write_srccorr): Don't write source correlation records if 0 lines.
14015 * xcoffout.c (xcoffout_end_epilogue): Add line and file args.
14016
9ef30f83
SE
140172002-08-15 Steve Ellcey <sje@cup.hp.com>
14018
14019 * gcc/unwind.h (_Unwind_Ptr): Make 64 bits on IA64 HP-UX.
14020 (_Unwind_Internal_Ptr): 32 bit version for use in
14021 read_encoded_value_with_base.
14022 * gcc/unwind-pe.h (read_encoded_value_with_base): Use
14023 _Unwind_Internal_Ptr instead of _Unwind_Ptr in order to get the
14024 right size.
14025
f7043461
KG
140262002-08-15 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
14027
14028 * loop.c (scan_loop, move_movables, count_one_set): Cast to avoid
14029 signed/unsigned warnings.
14030
14031 * regclass.c (init_reg_sets_1, choose_hard_reg_mode,
14032 record_reg_classes): Likewise.
14033
14034 * reload.c (reload_inner_reg_of_subreg, push_reload,
14035 find_reloads_address_1): Likewise.
14036
b4d330e1
DE
140372002-08-15 David Edelsohn <edelsohn@gnu.org>
14038
14039 * rs6000.c (output_mi_thunk): Return to function section on
14040 TARGET_ELF.
14041
14042 * rs6000-c.c (rs6000_cpu_cpp_builtins): Define __PPC405__ if PPC405.
14043
61f02ff5
UW
140442002-08-15 Ulrich Weigand <uweigand@de.ibm.com>
14045
14046 * config/s390/s390.c (legitimize_address): Optimize loading
14047 of large displacements.
14048
1330f7d5
DR
140492002-08-14 Douglas B Rupp <rupp@gnat.com>
14050
14051 * config/alpha/alpha-protos.h: Update.
14052
14053 * config/alpha/alpha.c: (LINKAGE_SYMBOL_REF_P): New macro.
14054 (alpha_legitimate_address_p): Test LINKAGE_SYMBOL_REF_P.
14055 (alpha_linkage_symbol_p): New static function.
14056 (print_operand_address): Print linkage operand.
14057
14058 (alpha_funcs_num, alpha_funcs_tree, alpha_links_tree): New static
14059 variables.
14060 (reloc_kind): New enum.
14061 (struct alpha_funcs): New struct.
14062 (struct alpha_links): Add reloc_kind field. Rename links_kind field.
14063
14064 (alpha_need_linkage): Rewrite.
14065 (alpha_use_linkage): New global function.
14066 (alpha_write_linkage): Rewrite and make static.
14067 (alpha_write_one_linkage): Rewrite
14068
14069 (alpha_start_function): Remove procedure descriptor output.
14070 (alpha_end_function): Write linkages at end of each function.
14071
14072 * config/alpha/alpha.md (call_vms, call_value_vms): Rewrite.
14073 (call_vms_1, call_value_vms_1): Rewrite.
14074
14075 * config/alpha/vms.h (ASM_FILE_END): Remove.
14076
d1f1cc6a
RH
140772002-08-14 Richard Henderson <rth@redhat.com>
14078
14079 * ggc-page.c (RTL_SIZE): New.
14080 (extra_order_size_table): Add specializations for 2 and 10 rtl slots.
14081 * rtl.def (BARRIER, NOTE): Pad to 9 slots.
14082
23626154
RH
140832002-08-14 Richard Henderson <rth@redhat.com>
14084
14085 * calls.c: Include target.h.
14086 * Makefile.in (calls.o): Update.
14087
14088 * config/alpha/alpha.c (alpha_end_function): Use targetm.binds_local_p.
14089 * config/alpha/alpha.h (FUNCTION_OK_FOR_SIBCALL): Likewise.
14090
fd350d24
RH
140912002-08-14 Richard Henderson <rth@redhat.com>
14092
14093 * Makefile.in (LOOSE_WARN): Add -fno-common.
14094 * c-common.h (constant_string_class_name): Add missing extern.
14095
182d89a3
NB
140962002-08-15 Neil Booth <neil@daikokuya.co.uk>
14097
14098 PR preprocessor/7358
14099 * c-opts.c (check_deps_environment_vars): Ignore main file
14100 for SUNPRO_DEPENDENCIES.
14101 * cppfiles.c (stack_include_file): Ignore main file if
14102 appropriate.
14103 * cpplib.h (struct cpp_options): New member in deps.
14104 * doc/cppenv.texi: Update.
14105
8bfb1467
NB
141062002-08-14 Neil Booth <neil@daikokuya.co.uk>
14107
14108 PR preprocessor/7526
14109 * cpplib.c (run_directive): Kludge so _Pragma dependency works.
14110
41685063
NS
141112002-08-14 Nathan Sidwell <nathan@codesourcery.com>
14112
14113 * doc/invoke.texi (-a): Remove documentation.
14114 (-fprofile-arcs): Remove reference to -a, -ax options.
14115 * doc/gcov.texi (Gcov Data Files): Data might be merged.
14116
77893a23
GDR
141172002-08-14 Gabriel Dos Reis <gdr@nerim.net>
14118
14119 Fix PR/7566
14120 * c-semantics.c (genrtl_case_label): Don't (mis)use
5ce6f47b 14121 warning_with_decl.
77893a23 14122
260f91c2
DJ
141232002-08-14 Dale Johannesen <dalej@apple.com>
14124
8537ed68 14125 * explow.c (emit_stack_restore): Emit memory clobbers
260f91c2
DJ
14126 preceding the stack pop, to prevent the scheduler from
14127 moving refs to variable arrays below this pop.
14128 * reload1.c (reload): Preserve these clobbers for sched2.
14129 * doc/rtl.texi: Document clobber (mem:BLK (scratch)).
14130
cd79e210
NB
141312002-08-14 Neil Booth <neil@daikokuya.co.uk>
14132
14133 * c-opts.c (c_common_post_options): Correct test.
14134
3eb75a73
KG
141352002-08-14 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
14136
14137 * m88k.h (ASM_OUTPUT_SOURCE_FILENAME): Fix incorrect argument
14138 order in call to fprintf.
14139
be3a0ce2
RO
141402002-08-14 Rainer Orth <ro@TechFak.Uni-Bielefeld.DE>
14141
14142 * config/sparc/sol2.h (SUBTARGET_EXTRA_SPECS): Define.
14143
ccfc6cc8
UW
141442002-08-14 Ulrich Weigand <uweigand@de.ibm.com>
14145
5ce6f47b 14146 * reload.c (find_reloads): Handle constraint letters marked by
ccfc6cc8
UW
14147 EXTRA_ADDRESS_CONSTRAINT and EXTRA_MEMORY_CONSTRAINT.
14148 (alternative_allows_memconst): Likewise.
14149 * reload1.c (maybe_fix_stack_asms): Likewise.
5ce6f47b 14150 * recog.c (asm_operand_ok, preprocess_constraints,
ccfc6cc8
UW
14151 constrain_operands): Likewise.
14152 * regclass.c (record_operand_costs, record_reg_classes): Likewise.
14153 * local-alloc.c (block_alloc, requires_inout): Likewise.
14154 * stmt.c (parse_output_constraint, parse_input_constraint): Likewise.
14155
14156 * defaults.h (EXTRA_MEMORY_CONSTRAINT): Provide a default.
14157 (EXTRA_ADDRESS_CONSTRAINT): Likewise.
14158 * doc/tm.texi: Document these two new target macros.
14159
14160 * config/s390/s390.c (s390_expand_plus_operand): Accept already
14161 valid operands.
14162 (q_constraint): New function.
14163 config/s390/s390-protos.h (q_constraint): Declare it.
14164 config/s390/s390.h (EXTRA_CONSTRAINT): Use it.
14165 (EXTRA_MEMORY_CONSTRAINT): New macro.
14166
14167 * config/s390/s390.md: Throughout the machine description,
14168 replace all instances of the constraint combinations 'Qo'
14169 or 'oQ' with simply 'Q'.
14170
d6ee9f6f
SC
141712002-08-14 Stephane Carrez <stcarrez@nerim.fr>
14172
14173 * config/m68hc11/m68hc11.h (LINK_SPEC): Support -mrelax.
14174 * config/m68hc11/t-m68hc11-gas (LIBGCC2_DEBUG_CFLAGS): Can use -g now.
14175 (LIBGCC2_CFLAGS): Compile with -mrelax.
14176
8a0b86f5
SC
141772002-08-14 Stephane Carrez <stcarrez@nerim.fr>
14178
14179 * doc/invoke.texi: Document -minmax for 68HC12.
14180
14181 * config/m68hc11/m68hc11.md ("umaxqi3"): Use TARGET_MIN_MAX.
14182 ("uminqi3"): Likewise.
14183 ("uminhi3", "umaxhi3"): Likewise.
14184
14185 * config/m68hc11/m68hc11.h (MASK_MIN_MAX): Define.
14186 (TARGET_MIN_MAX): Define.
14187 (TARGET_SWITCHES): New option -minmax/-mnominmax.
14188
d6381f4e
SC
141892002-08-14 Stephane Carrez <stcarrez@nerim.fr>
14190
14191 * config/m68hc11/t-m68hc11-gas (LIB1ASMFUNCS): Build __far_trampoline.
14192 (MULTILIB_OPTIONS): Must also generate for -mlong-calls.
14193
14194 * config/m68hc11/larith.asm: Put a mode for ELF ABI flags.
14195 (ret, declare, farsym): New gas macros.
14196 (__premain, exit, abort, _cleanup, memcpy, memset, ___adddi3,
14197 ___subdi3, ___notdi2, __mulhi32, __mulsi3): Use them to use 'rtc'
14198 and declare the symbol far when compiled with -mlong-calls.
5ce6f47b 14199 (__far_trampoline): New for 68HC12 trampoline code to invoke a
d6381f4e
SC
14200 far handler using jsr/bsr.
14201
14202 * config/m68hc11/m68hc11-crt0.S: Put a mode for ELF ABI flags.
14203 (jsr): New macro to transform a 'jsr' into a 'call'.
14204
058edcdb
SC
142052002-08-14 Stephane Carrez <stcarrez@nerim.fr>
14206
14207 * doc/invoke.texi: Document -mlong-calls for 68HC12.
14208
14209 * config/m68hc11/m68hc11.h (CPP_SPEC): Pass -D__USE_RTC__ when
14210 -mlong-calls is specified.
5ce6f47b 14211 (ASM_DECLARE_FUNCTION_NAME): Define to generate .far and .interrupt
058edcdb
SC
14212 assembler directives.
14213 (TARGET_LONG_CALL, MASK_LONG_CALL): Declare.
14214 (TARGET_SWITCHES): Add -mlong-calls options.
14215 (current_function_far): Declare.
14216
14217 * config/m68hc11/m68hc11.c (m68hc11_initial_elimination_offset): Take
14218 into account the page register saved on the stack.
14219 (m68hc11_override_options): Take into account -mlong-calls option.
14220 (m68hc11_asm_file_start): Put a mode for the ELF flags ABI.
14221
14222 * config/m68hc11/m68hc11.md ("*return_32bit"): Return rtc
14223 if the function is going to be in 68HC12 banked memory (-mlong-calls).
14224 ("*return_16bit"): Likewise.
14225 ("*return_void"): Likewise.
14226 ("call", "call_value"): Use call for a far function call.
14227
c79043f3
NB
142282002-08-14 Neil Booth <neil@daikokuya.co.uk>
14229
14230 * toplev.c (parse_options_and_default_flags): Don't call
14231 post_options here.
14232 (general_init): Initialize GC, pools and tree hash here,
14233 instead of lang_independent_init.
14234 (lang_independent_init): Rename backend_init.
14235 (do_compile): Call post_options hook; exit early if there
14236 have been errors after switch processing.
14237 (toplev_main): Update.
14238
6bf346d4
GDR
142392002-08-14 Gabriel Dos Reis <gdr@nerim.net>
14240
14241 * c-pretty-print.h: Guard against multiple inclusion.
14242 Robustify macros.
14243 (pp_c_attributes): Declare.
14244 * c-pretty-print.c (pp_c_attributes): New function.
14245
cbf2f479
KG
142462002-08-13 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
14247
14248 * m68k.c (m68k_output_function_prologue,
14249 m68k_output_function_epilogue): Delete versions for DPX2/MOTOROLA
14250 and NEWS/MOTOROLA.
14251 * genattrtab.c: Remove dpx2 comment.
14252 * libgcc2.c (__enable_execute_stack): Delete versions for
14253 NeXT/__MACH__, __convex__, __sysV88__, __pyr__ and
14254 sony_news/SYSTYPE_BSD.
14255 * longlong.h: Delete code for __a29k__, _AM29K, __clipper__,
14256 __gmicro__, __i860__, __NeXT__ and __pyr__.
14257 * rtl.h: Remove convex comment.
14258 * varasm.c: Likewise.
14259
d3969c34
KG
142602002-08-13 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
14261
14262 * c-opts.c (lang_flags): Const-ify.
14263 * ra-build.c (undef_table): Likewise.
14264 * ra.c (eliminables): Likewise.
14265
df89f8e7
GDR
142662002-08-14 Gabriel Dos Reis <gdr@nerim.net>
14267
14268 * tree.h: Guard against multiple inclusion.
14269
cf87d551
HPN
142702002-08-14 Hans-Peter Nilsson <hp@bitrange.com>
14271
14272 * reload1.c (reload_cse_simplify): Before checking
14273 REG_FUNCTION_VALUE_P, check REG_P.
14274
a43c8986
GK
142752002-08-13 Geoffrey Keating <geoffk@redhat.com>
14276
14277 * Makefile.in (attribs.o): Remove $(OBSTACK_H) dependency.
14278
29337351
NB
142792002-08-13 Neil Booth <neil@daikokuya.co.uk>
14280
14281 * c-opts.c (c_common_init_options): Extra braces needed.
14282
8202c8c4
R
14283Tue Aug 13 17:40:25 2002 J"orn Rennecke <joern.rennecke@superh.com>
14284
14285 * sh.c (sh_init_builtins): Add PARAMS to declaration.
14286 (sh_media_init_builtins, sh_expand_builtin): Likewise.
14287 (sh_expand_unop_v2sf): Use PARAMS for variable declaration.
14288 (sh_expand_binop_v2sf): Likewise.
14289 * sh-protos.h (sh_expand_unop_v2sf): Add PARAMS to declaration.
14290 (sh_expand_binop_v2sf, sh_cfun_interrupt_handler_p): Likewise.
14291 (sh_initialize_trampoline): Likewise.
14292
07893d4f
UW
142932002-08-13 Ulrich Weigand <uweigand@de.ibm.com>
14294
14295 * s390-modes.def [CCL1, CCL2, CCT1, CCT2, CCT3, CCUR, CCSR]: Declare
14296 new condition code modes.
14297 s390.c (s390_match_ccmode_set): Handle those new CC modes.
14298 (s390_select_ccmode): Likewise.
14299 (s390_branch_condition_mask): Likewise.
14300
14301 * s390-protos.h (s390_tm_ccmode): Declare.
14302 s390.c (s390_tm_ccmode): New function.
14303 (s390_match_ccmode): Allow VOIDmode as REQ_MODE.
14304
14305 * s390.md ("*cmpdi_tm2"): Rename to "*tmdi_ext".
14306 ("*cmpsi_tm2"): Rename to "*tmsi_ext".
14307 ("*cmpqi_tm2"): Rename to "*tmqi_ext".
14308
14309 ("*cmpdi_tm_reg", "*cmpdi_tm_mem", "*cmpsi_tm_reg", "*cmpsi_tm_mem",
14310 "*cmphi_tm_sub","*cmphi_cct_0", "*cmpqi_tm", "*cmpqi_tm_sub",
14311 "*cmpqi_cct_0", "*tm_0"): Remove, replace by ...
14312 ("*tmdi_reg", "*tmsi_reg", "*tmdi_mem", "*tmsi_mem", "*tmhi_mem",
14313 "*tmqi_mem", "*tmhi_full", "*tmqi_full"): ... these new patterns.
14314
14315 ("*ltgr", "*cmpdi_ccs_0_64", "*cmpdi_ccs_0_31", "*ltr", "*icm15",
5ce6f47b 14316 "*icm15_cconly", "*cmpsi_ccs_0", "*icm3", "*cmphi_ccs_0", "*icm1",
07893d4f
UW
14317 "*cmpqi_ccs_0"): Remove, replace by ...
14318 ("*tstdi_sign", "*tstdi", "*tstdi_cconly", "*tstdi_cconly_31",
5ce6f47b 14319 "*tstsi", "*tstsi_cconly", "*tstsi_cconly2", "*tsthi", "*tsthi_cconly",
07893d4f
UW
14320 "*tstqi", "*tstqi_cconly"): ... these new patterns.
14321
14322 ("*cmpsidi_ccs"): Remove, replace by ...
14323 ("*cmpsi_ccs_sign"): ... this new pattern.
14324 ("*cmpdi_ccs_sign", "*cmpdi_ccu_zero"): New patterns.
14325
14326 ("*cmpqi_ccu_0", "*cmpqi_ccu_immed"): Remove, replace by ...
14327 ("*cli"): ... this new pattern.
14328
14329 ("*adddi3_sign", "*adddi3_zero_cc", "*adddi3_zero_cconly",
14330 "*adddi3_zero", "*adddi3_cc", "*adddi3_cconly", "*adddi3_cconly2"):
14331 New patterns.
14332 ("adddi3_64"): Rename to "*adddi3_64".
14333 ("adddi3_31"): Replace by insn and splitter "*adddi3_31".
14334 ("adddi3"): Adapt expander.
14335
14336 ("*addsi3_cc"): Allow "general_operand" for operand 2.
5ce6f47b 14337 ("*addsi3_carry1_cc", "*addsi3_carry1_cconly",
07893d4f
UW
14338 "*addsi3_carry2_cc", "*addsi3_carry2_cconly"): New patterns.
14339
14340 ("addhi3", "addqi3"): Remove, replace by ...
14341 ("*addsi3_sign", "*addsi3_sub"): ... these new patterns.
14342
14343 ("*subdi3_sign", "*subdi3_zero_cc", "*subdi3_zero_cconly",
14344 "*subdi3_zero", "*subdi3_cc", "*subdi3_cconly"): New patterns.
14345 ("subdi3"): Replace by insn and splitter "*subdi3_31".
14346 ("subdi3"): New expander.
14347
14348 ("*subsi3_borrow_cc", "*subsi3_borrow_cconly"): New patterns.
14349
14350 ("subhi3", "subqi3"): Remove, replace by ...
14351 ("*subsi3_sign", "*subsi3_sub"): ... these new patterns.
14352
14353 ("*muldi3_sign"): New pattern.
14354 ("muldi3"): Do not clobber CC.
14355 ("mulsi3"): Likewise.
14356 ("mulsi_6432"): Likewise.
14357
db62867b
DC
143582002-08-13 Denis Chertykov <denisc@overta.ru>
14359
14360 * config/avr/avr.md: Call CC_STATUS_INIT in all peepnoles
8537ed68 14361 which can change CC0.
db62867b 14362
8ba46434
R
14363Tue Aug 13 14:49:20 2002 J"orn Rennecke <joern.rennecke@superh.com>
14364
14365 * gcse.c (adjust_libcall_notes): New function.
14366 (do_local_cprop): Use it. Add fourth parameter. Changed caller.
14367
8733892f
NS
143682002-08-13 Nathan Sidwell <nathan@codesourcery.com>
14369
14370 * libgcc2.c (L_bb): Remove unneeded #includes.
14371 (__global_counters, __gthreads_active): Remove unused globals.
14372 (__bb_exit_func): Merge counts into files rather than appending.
14373 * Makefile.in (INTERNAL_CFLAGS): Move COVERAGE_FLAGS from here ...
14374 (ALL_CFLAGS): ... to here.
14375
f4769721
DC
143762002-08-13 Denis Chertykov <denisc@overta.ru>
14377
14378 * config/ip2k/ip2k.c (commands_in_file): Variable removed.
14379 (function_epilogue): Don't calculate function size.
14380 (ip2k_set_compare): Don't use lookup_const_double.
14381 (asm_file_start): Initialization of commands_in_file removed.
14382 (asm_file_end): Output of commands_in_file removed.
5ce6f47b 14383
f4769721
DC
14384 * config/ip2k/ip2k.c (CPP_PREDEFINES): Remove definition of
14385 __INT_MAX__.
14386
c31cddfd
NB
143872002-08-13 Neil Booth <neil@daikokuya.co.uk>
14388
14389 * c-opts.c (c_common_init_options): Check option array is
14390 sorted if checking enabled.
14391
f076f0ce
GDR
143922002-08-13 Gabriel Dos Reis <gdr@nerim.net>
14393
14394 * c-pretty-print.c: #include "c-tree.h".
14395 (pp_c_simple_type_specifier): Tweak.
14396 (pp_c_storage_class_specifier): New.
14397 (pp_c_function_specifier): Likewise.
14398 (pp_c_declaration_specifiers): Likewise.
14399 (pp_c_init_declarator): Likewise.
14400 (pp_c_declaration): Likewise.
14401 (pp_c_direct_declarator): Stub.
14402 (pp_c_declarator): Likewise.
14403 (pp_c_parameter_declaration): Likewise.
14404
f4ff5a69
NB
144052002-08-13 Neil Booth <neil@daikokuya.co.uk>
14406
14407 * c-opts.c (deps_seen, deps_file, deferred_count, deferred_size,
14408 handle_deferred_opts, sanitize_cpp_opts, defer_opt,
14409 struct deferred_opt): New.
14410 (COMMAND_LINE_OPTIONS): Add -M*.
14411 (missing_arg): Update.
14412 (c_common_decode_option): Handle -M*.
14413 (c_common_post_options): Handle -M*. Use sanitize_cpp_opts;
14414 don't call cpp_post_options.
14415 (c_common_finish, check_deps_environment_vars): Update.
14416 * cppfiles.c (stack_include_file, handle_missing_header): Update.
14417 * cpphash.h (CPP_PRINT_DEPS): Remove.
14418 * cppinit.c: Don't include version.h.
14419 (cpp_create_reader): Don't call deps_init. Initialize
14420 warn_long_long.
14421 (cpp_read_main_file): Init deps if necessary.
14422 (cpp_destroy): Conditionally free deps.
14423 (cpp_finish): Update.
14424 (no_tgt): Remove.
14425 (COMMAND_LINE_OPTIONS, cpp_handle_option): Remove -M*.
14426 (cpp_post_options): Rename post_options.
14427 * cpplib.h (struct cpp_options): Remove some dependency options;
14428 move others to a new structure.
14429 (cpp_post_options): Remove.
14430 (cpp_finish): Comment.
14431 * fix-header.c (read_scan_file): Don't call cpp_post_options.
14432
34116c2a
HPN
144332002-08-12 Hans-Peter Nilsson <hp@bitrange.com>
14434
14435 * config/mmix/mmix.md (define_constants): Add MMIX_rR_REGNUM.
14436 ("divdi3", "*divdi3_nonknuth", "moddi3", "*moddi3_nonknuth"): Mark
14437 MMIX_rR_REGNUM as clobbered.
14438 * config/mmix/mmix.h (MMIX_REMAINDER_REGNUM): Use MMIX_rR_REGNUM.
14439
9b32718c
GDR
144402002-08-12 Gabriel Dos Reis <gdr@nerim.net>
14441
14442 * diagnostic.h (output_formatted_scalar): Rename from
5ce6f47b 14443 output_formatted_integer.
9b32718c
GDR
14444 * diagnostic.def: Add DK_DEBUG.
14445 * diagnostic.c (output_decimal): Adjust.
14446 (output_long_decimal): Likewise.
14447 (output_unsigned_decimal): Likewise.
14448 (output_octal): Likewise.
14449 (output_long_octal): Likewise.
14450 (output_hexadecimal): Likewise.
14451 (output_long_hexadecimal): Likewise.
14452 * c-pretty-print.c (pp_c_type_specifier): New function.
14453 (pp_c_specifier_qualifier_list): Likewise.
14454 (pp_c_abstract_declarator): Likewise.
14455 (pp_c_char): Replace pp_format_integer with pp_format_scalar.
14456
032613df
DE
144572002-08-12 David Edelsohn <edelsohn@gnu.org>
14458
14459 * doc/trouble.texi (Disappointments): Add static constructor and
14460 destructor dependency information for AIX.
14461
a3737481
NB
144622002-08-12 Neil Booth <neil@daikokuya.co.uk>
14463
14464 * cpphash.h (struct printer): New from cppmain.c.
14465 (cpp_reader): New member.
14466 * cppmain.c (struct printer): Move to cpphash.h.
14467 (options, print): Remove.
14468 (account_for_newlines, print_line, maybe_print_line,
14469 cpp_preprocess_file, setup_callbacks, scan_translation_unit,
14470 scan_translation_unit_trad, cb_line_change, cb_ident,
14471 cb_define, cb_undef, cb_include, cb_file_change, dump_macro,
14472 cb_def_pragma): Make reentrant.
14473
d71f7700
KG
144742002-08-12 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
14475
14476 * real.c (ieee_64): Always define.
14477 (ieee_113): Guard with INTEL_EXTENDED_IEEE_FORMAT == 0.
14478 (dec_h): Not used yet, hide it.
14479 (emdnorm): Mark parameter in ATTRIBUTE_UNUSED. Guard label with
14480 macro controlling use.
14481 (TFbignan, TFlittlenan): Guard with INTEL_EXTENDED_IEEE_FORMAT == 0.
14482
c16576e6
JH
14483Mon Aug 12 12:48:20 CEST 2002 Jan Hubicka <jh@suse.cz>
14484
14485 * i386.md (tablejump): Sign extend the operand.
14486 * i386.c (classify_argument): Fix missed case from previous patch.
14487
460bd0e3
NB
144882002-08-12 Neil Booth <neil@daikokuya.co.uk>
14489
14490 * c-common.c (STDC_0_IN_SYSTEM_HEADERS, c_common_init): Move
14491 to c-copts.c.
14492 (warn_multichar): Die.
14493 (cb_register_builtins): Export.
14494 * c-common.h (warn_multichar, preprocess_file): Remove.
14495 (cb_register_builtins): New.
14496 * c-lang.c (c_init): Remove.
14497 (LANG_HOOKS_INIT): Use c_objc_common_init.
14498 * c-lex.c (init_c_lex): Don't canonicalize filename.
14499 * c-opts.c (in_fname, STDC_0_IN_SYSTEM_HEADERS): New.
14500 (preprocess_file): Make static. Update for cpplib.
14501 (c_common_decode_option): Remove warn_multichar. Use in_fname.
14502 (c_common_post_options): Set some cpp options here.
14503 (c_common_init): Move from c-common.c.
14504 * cppinit.c (cpp_post_options): Don't canonicalize in_fname.
14505 * cpplib.h (struct cpp_options): Remove in_fname.
14506 (cpp_preprocess_file): Update.
14507 * cppmain.c (cpp_preprocess_file): Update for new prototypes.
14508
f3f268dd
KG
145092002-08-11 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
14510
14511 * config.gcc (mips*-*-netbsd*): Include ${tm_file}.
14512
f0201fba
KG
145132002-08-11 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
14514
14515 * i370.h (TARGET_CPU_CPP_BUILTINS): Remove spurious trailing
14516 backslash in comment preceeding macro definition.
14517 * i370/linux.h (TARGET_OS_CPP_BUILTINS): Likewise.
14518 * i370/mvs.h (TARGET_OS_CPP_BUILTINS): Likewise.
14519 * i370/oe.h (TARGET_OS_CPP_BUILTINS): Likewise.
14520
e56fc090
HPN
145212002-08-12 Hans-Peter Nilsson <hp@bitrange.com>
14522
14523 * expr.c (store_expr): In condition for checking if value is
14524 generated in TARGET, move call to expr_size last.
14525
76c3e73e
NB
145262002-08-11 Neil Booth <neil@daikokuya.co.uk>
14527
14528 * c-common.c (c_common_init): Call preprocess_file instead.
14529 (c_common_finish): Move to c-opts.c.
14530 * c-common.h (preprocess_file): new.
14531 * c-opts.c (out_fname, out_stream, deps_append, preprocess_file,
14532 check_deps_environment_vars, c_common_finish): New.
14533 (c_common_decode_option): Update for out_fname and dependencies.
14534 * cppinit.c (init_dependency_output, output_deps): Remove.
14535 (cpp_destroy): Update prototype.
14536 (cpp_add_dependency_target): New.
14537 (cpp_read_main_file): Don't overlay a buffer.
14538 (cpp_finish): Take a deps output stream and write deps to it.
14539 Return the error count.
14540 (cpp_post_options): Don't canonicalize out_fname, or do anything
14541 with dependencies.
14542 * cpplib.h (struct cpp_options): Remove out_fname and
14543 preprocess_only.
14544 (cpp_add_dependency_target): New.
14545 (cpp_destroy, cpp_finish, cpp_preprocess_file): Update.
14546 * cppmain.c (cpp_preprocess_file): Update prototype. Don't
14547 set preprocess_only. Don't handle the output stream directly.
14548
e0c32c62
KG
145492002-08-11 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
14550
14551 * dsp16xx.c (print_operand): Fix format specifier.
14552 * dsp16xx.md: Avoid automatic aggregate initialization.
14553 * frv.h (REG_CLASS_FROM_LETTER): Avoid char as array index.
14554 * h8300.c (emit_a_rotate, h8300_adjust_insn_length): Avoid U
14555 integer constant modifier.
14556 * ip2k.c (ip2k_set_compare): Avoid signed/unsigned warning.
14557 * mmix-protos.h (mmix_use_simple_return): Move outside TREE_CODE
14558 guards.
14559 * sh/netbsd-elf.h (FUNCTION_PROFILER): Fix format specifier.
14560 * v850.c (v850_select_section): Mark parameter with
14561 ATTRIBUTE_UNUSED.
14562 * global.c (global_alloc): Const-ify.
14563 * ra-colorize.c (hardregset_to_string): Fix format specifier.
14564
7ae8cf75
KG
145652002-08-11 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
14566
14567 * darwin-c.c (darwin_pragma_options): Const-ify.
14568 * darwin.c (machopic_non_lazy_ptr_name,
14569 machopic_validate_stub_or_non_lazy_ptr): Likewise.
14570 (machopic_indirect_data_reference): Wrap variables in macros
14571 controlling their use.
14572 (machopic_finish, update_non_lazy_ptrs, update_stubs): Const-ify.
14573 (machopic_select_section): Use parentheses around && within ||.
14574 * i386/darwin.h (ASM_OUTPUT_ALIGN): Avoid ambiguous-else.
14575
8819cab5
KG
145762002-08-11 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
14577
14578 * ip2k.c (mdr_resequence_xy_yx, mdr_propagate_reg_equivs,
14579 mdr_try_move_dp_reload, ip2k_check_can_adjust_stack_ref,
14580 ip2k_adjust_stack_ref, mdr_try_move_pushes, mdr_try_propagate_clr,
14581 ip2k_xexp_not_uses_reg_for_mem, mdr_try_propagate_move,
14582 mdr_try_remove_redundant_insns, track_w_reload,
14583 mdr_try_wreg_elim): Make function static to match prototype.
14584 * mmix.c (mmix_target_asm_function_epilogue): Likewise. Mark
14585 parameter with ATTRIBUTE_UNUSED.
14586
ab2877a3
KG
145872002-08-11 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
14588
14589 * arc.c (arc_init): Don't use ISO C style function definitions.
14590 * arm.c (count_insns_for_constant, thumb_far_jump_used_p,
14591 arm_get_strip_length, arm_strip_name_encoding): Likewise.
14592 * avr.h (progmem_section): Likewise.
14593 * h8300.c h8300_asm_insn_count): Likewise.
14594 * m32r.c (init_idents): Likewise.
14595 * s390.c (s390_split_branches, s390_chunkify_pool): Likewise.
14596 * sh.c (sh_cfun_interrupt_handler_p): Likewise.
14597 * xtensa.c (xtensa_build_va_list): Likewise.
14598
08767a6f
NB
145992002-08-11 Neil Booth <neil@daikokuya.co.uk>
14600
14601 * c-common.h (enum c_language_kind): Emphasize that clk_c is 0.
14602 * c-opts.c (parse_option): Rename find_opt.
14603 (set_std_c99): New function.
14604 (COMMAND_LINE_OPTIONS): Handle -remap and -o. Remove OPT_std_bad.
14605 (missing_arg): Remove OPT_std_bad. Handle -o.
14606 (c_common_decode_option): Handle input and output file names,
14607 -o and -remap. Clean up -std= handling.
14608 * cppinit.c (COMMAND_LINE_OPTIONS): Remove OPT_o and OPT_remap.
14609 (cpp_handle_option): Similarly. Don't handle filenames.
14610
db01f480
JH
14611Sun Aug 11 14:43:17 CEST 2002 Jan Hubicka <jh@suse.cz>
14612
14613 * i386.c (classify_argument): Fix computing of field's offsets.
14614
a7701995
AJ
146152002-08-11 Andreas Jaeger <aj@suse.de>
14616
14617 PR target/7531:
14618 * doc/invoke.texi (i386 and x86-64 Options): Document -mcmodel.
14619
2516f236
ZL
146202002-08-10 Ziemowit Laski <zlaski@apple.com>
14621
14622 * config/alpha/alpha.h (TARGET_CPU_CPP_BUILTINS): Replace
14623 reference to clk_objective_c with flag_objc.
14624 * config/i386/i386-interix.h (TARGET_OS_CPP_BUILTINS):
14625 Likewise.
14626 * config/mips/mips.h (TARGET_CPU_CPP_BUILTINS): Likewise.
14627
f749a36b
NB
146282002-08-10 Neil Booth <neil@daikokuya.co.uk>
14629
14630 * c-opts.c (set_std_cxx98, set_std_c89): New.
14631 (COMMAND_LINE_OPTIONS): Move more from cppinit.c.
14632 (c_common_decode_option): Handle new switches from cppinit.c.
14633 Add -std=gnu++98.
14634 * cppinit.c (set_lang): Rename cpp_set_lang. Export.
14635 (no_arg, no_num): Remove.
14636 (COMMAND_LINE_OPTIONS): Move more to c-opts.c. Drop all lang-
14637 switches apart from -lang-objc and lang-asm.
14638 (cpp_handle_option): Similarly.
14639 * cpplib.h (cpp_set_lang): New.
14640 * doc/cppopts.texi, doc/invoke.texi: Document -std=c++98,
14641 -std=gnu++98.
14642 * objc/lang-specs.h: Remove -ansi.
14643
77abb5d8
JH
14644Sat Aug 10 19:59:43 CEST 2002 Jan Hubicka <jh@suse.cz>
14645 Graham Stott
14646
14647 * cfg.c (redirect_edge_succ_nodup): Avoid overflows due to roundoff
14648 errors.
14649
fac37dc4
KG
146502002-08-10 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
14651
d950dee3
KG
14652 * emit-rtl.c (emit_jump_insn_before, emit_call_insn_before,
14653 emit_jump_insn): Fix uninitialized variable.
14654 * gcov.c (init_line_info): Likewise.
14655 * genautomata.c (transform_3): Add braces around ambiguous
14656 else.
14657 * ifcvt.c (cond_exec_process_insns): Mark parameter with
14658 ATTRIBUTE_UNUSED.
14659 * ra-build.c (parts_to_webs_1): Fix uninitialized variable.
14660 * regrename.c (copyprop_hardreg_forward): Fix uninitialized
14661 variable.
14662
fac37dc4
KG
14663 * gengtype.c (write_gc_structure_fields): Avoid signed/unsigned
14664 warnings in output files.
14665
0f7866e7
ZL
146662002-08-09 Ziemowit Laski <zlaski@apple.com>
14667
14668 * c-common.c (flag_objc): New.
14669 * c-common.h (c_language_kind): Get rid of clk_objective_c
14670 enum value.
14671 (flag_objc): New extern declaration.
14672 * c-decl.c (implicitly_declare): Call objc_check_decl
14673 instead of maybe_objc_check_decl.
14674 (finish_decl): Likewise.
14675 (grokfield): Likewise.
14676 (finish_struct): Likewise.
14677 * c-lang.c (maybe_objc_check_decl): Rename to objc_check_decl.
14678 (maybe_objc_comptypes): Rename to objc_comptypes.
a7701995 14679 (maybe_building_objc_message_expr): Rename to
0f7866e7
ZL
14680 objc_message_selector.
14681 * c-lex.c (lex_charconst): Remove uses of clk_objective_c,
14682 replace with flag_objc as needed.
14683 * c-opts.c (c_common_init_options): Likewise.
14684 (c_common_decode_option): Likewise.
14685 * c-parse.in (init_reswords): Likewise.
14686 * c-tree.h (maybe_objc_check_decl): Rename to objc_check_decl.
14687 (maybe_objc_comptypes): Rename to objc_comptypes.
a7701995 14688 (maybe_building_objc_message_expr): Rename to
0f7866e7
ZL
14689 objc_message_selector.
14690 * c-typeck.c (comptypes): Call objc_comptypes instead of
14691 maybe_objc_comptypes, and/or objc_message_selector instead of
14692 maybe_building_objc_message_expr.
14693 (comp_target_types): Likewise.
14694 (convert_for_assignment): Likewise.
14695 (warn_for_assignment): Likewise.
14696 * cppinit.c (init_builtins): Set __OBJC__ manifest constant
14697 independently of those for other languages.
14698 * objc/objc-act.c (maybe_objc_comptypes): Delete.
14699 (maybe_objc_check_decl): Delete.
a7701995 14700 (maybe_building_objc_message_expr): Rename to
0f7866e7
ZL
14701 objc_message_selector.
14702 * objc/objc-lang.c (objc_init_options): Use clk_c instead of
14703 clk_objective_c; set flag_objc flag.
14704
c512fd7b
TM
147052002-08-09 Toshiyasu Morita <toshiyasu.morita@hsa.hitachi.com>
14706
14707 * ifcvt.c (find_if_case_2): Test correct basic block for size.
14708
5e1bf043 147092002-08-09 Dale Johannesen <dalej@apple.com>
c512fd7b 14710
5e1bf043
DJ
14711 * config/rs6000/rs6000.md: Add sibcall patterns.
14712 * config/rs6000/rs6000.h (FUNCTION_OK_FOR_SIBCALL): Define.
14713 * config/rs6000/rs6000.c (rs6000_ra_ever_killed):
14714 Rewritten to handle sibcalls.
14715 * config/rs6000/rs6000.c (function_ok_for_sibcall): New.
14716 * config/rs6000/rs6000-protos.h (function_ok_for_sibcall): New.
14717
2043c38e
NS
147182002-08-08 Nathan Sidwell <nathan@codesourcery.com>
14719
14720 * profile.c (da_file_name): New static var.
14721 (init_branch_prob): Initialize it.
14722 (end_branch_prob): Remove da file.
14723
14724 * Makefile.in (stage1_build): Pass empty COVERAGE_FLAGS.
41685063 14725 * configure.in (coverage_flags): Default to nothing.
2043c38e
NS
14726 * configure: Rebuilt.
14727
4b7091eb
NB
147282002-08-09 Neil Booth <neil@daikokuya.co.uk>
14729
14730 * Makefile.in (c-opts.o): Update
14731 * c-opts.c: Include intl.h.
14732 (print_help): Move from cppinit.c. Remove unused options.
14733 (COMMAND_LINE_OPTIONS): Move more from cppinit.c.
14734 (missing_arg): Complain for switches without an argument.
14735 (c_common_decode_option): Reject missing joined arguments.
14736 Handle new switches from cppinit.c.
14737 * cppinit.c (COMMAND_LINE_OPTIONS): Move some switches to c-opts.c.
14738 (cpp_handle_option): Similarly.
14739 (print_help): Moved to c-opts.c.
14740 * cpplib.h (struct cpp_options): Remove help_only.
14741 * gcc.c (cpp_unique_options): Remove -$.
14742 * doc/cppopts.texi: Undocument -h.
14743
9e20be0c
JJ
147442002-08-08 Jakub Jelinek <jakub@redhat.com>
14745
14746 * config/i386/i386.c (legitimate_constant_p): UNSPEC_TP is not
14747 legitimate constant.
14748 (legitimate_pic_operand_p): Neither pic operand.
14749 (legitimate_address_p): But legitimate address.
14750 (get_thread_pointer): Generate MEM/u instead of CONST around
14751 UNSPEC_TP.
14752 (print_operand): Remove printing of UNSPEC_TP.
14753 (print_operand_address): And print it here.
14754
7b9be5c7 147552002-08-08 Devang Patel <dpatel@apple.com>
9e20be0c 14756
a7701995
AJ
14757 * objc/objc-act.c (build_selector_translation_table): Issue warning,
14758 when -Wselector is used,if method for which selector is being
7b9be5c7 14759 created does not exist.
a7701995 14760
5615d8fd
SC
147612002-08-08 Stephen Clarke <stephen.clarke@superh.com>
14762
14763 * config/sh/sh.c (prepare_move_operands): Only call
14764 target_reg_operand if TARGET_SHMEDIA.
a7701995 14765
3b85fe5f
JJ
147662002-08-08 Jakub Jelinek <jakub@redhat.com>
14767
14768 * config/rs6000/rs6000.h, config/rs6000/aix.h,
14769 config/rs6000/darwin.h, config/rs6000/linux64.h: Revert last
14770 two patches.
14771 * config/rs6000/sysv4.h: Likewise, remove #undef ADJUST_FIELD_ALIGN.
14772
e10c79fe
LB
147732002-08-08 Lars Brinkhoff <lars@nocrew.org>
14774 Richard Henderson <rth@redhat.com>
14775
14776 * emit-rtl.c (gen_rtx_REG): After reload, only return
14777 frame_pointer_rtx or hard_frame_pointer_rtx if frame_pointer_needed.
14778
aa2a83dc
JJ
147792002-08-08 Jakub Jelinek <jakub@redhat.com>
14780
14781 * config/rs6000/rs6000-protos.h (rs6000_field_alignment): Remove.
14782 * config/rs6000/rs6000.c (rs6000_field_alignment): Move...
14783 * config/rs6000/rs6000.h (ADJUST_FIELD_ALIGN): ...inline into the
14784 macro.
14785
aeaf4d25
AN
147862002-08-08 Adam Nemet <anemet@lnxw.com>
14787
14788 * config/arm/arm.c (thumb_unexpanded_epilogue): Stack the PIC
14789 register.
14790 (thumb_expand_prologue): Likewise.
14791 (thumb_output_function_prologue): Likewise.
14792 * config/arm/arm.h (THUMB_INITIAL_ELIMINATION_OFFSET): Account for
14793 the additional push of the PIC register.
14794
22aa533e
NS
147952002-08-08 Nathan Sidwell <nathan@codesourcery.com>
14796
14797 * configure.in (enable_coverage): New enable switch.
14798 * configure: Rebuilt.
14799 * Makefile.in (COVERAGE_FLAGS, coverageexts): New variables.
14800 (INTERNAL_CFLAGS): Append COVERAGE_FLAGS.
14801 (ALL_FLAGS): Reorder so INTERNAL_CFLAGS comes after CFLAGS.
14802 (mostlyclean): Remove coverage files.
14803 * doc/install.texi: Document enable_coverage.
14804
14805 * cp/Make-lang.in (c++.mostlyclean): Remove coverage files.
14806 * ada/Make-lang.in (ada.mostlyclean): Remove coverage files.
14807 * f/Make-lang.in (f.mostlyclean): Remove coverage files.
14808 * java/Make-lang.in (java.mostlyclean): Remove coverage files.
14809 * objc/Make-lang.in (objc.mostlyclean): Remove coverage files.
14810 * treelang/Make-lang.in (treelang.mostlyclean): Remove coverage
14811 files.
a7701995 14812
18bdccaa
NB
148132002-08-08 Neil Booth <neil@daikokuya.co.uk>
14814
14815 * c-opts.c (cpp_opts): New.
14816 (COMMAND_LINE_OPTIONS): Add switches from cppinit.c.
14817 (c_common_decode_options): Handle cpplib switches.
14818 (c_common_init_options): Set cpp_opts.
14819 * cppinit.c (COMMAND_LINE_OPTIONS): Move some switches to c-opts.c.
14820 (cpp_handle_option): Similarly.
14821
774b5662
DE
148222002-08-08 David Edelsohn <edelsohn@gnu.org>
14823
14824 * config/rs6000/aix.h (TARGET_ALTIVEC): Define to 0.
14825 (TARGET_ALTIVEC_ABI): Same.
14826 (TARGET_ALTIVEC_VRSAVE): Same.
14827
14828 * config/rs6000/rs6000.c (rs6000_expand_ternop_builtin): Check
14829 icode not CODE_FOR_nothing. Change switch to if.
14830
957e9e48
AM
148312002-08-08 Alan Modra <amodra@bigpond.net.au>
14832
14833 * config/rs6000/rs6000.h (ASM_CPU_SPEC): Pass -mpower4 when cpu=power4.
14834
daf06049
JJ
148352002-08-08 Jakub Jelinek <jakub@redhat.com>
14836
14837 * stor-layout.c (place_union_field): For bitfields if
14838 PCC_BITFIELD_TYPE_MATTERS and TYPE_USER_ALIGN, set record's
14839 TYPE_USER_ALIGN.
14840
043d39a6
JDA
148412002-08-07 John David Anglin <dave@hiauly1.hia.nrc.ca>
14842
14843 * pa.c (struct deferred_plabel): Constify name field.
14844
34bb92e3
NB
148452002-08-07 Neil Booth <neil@daikokuya.co.uk>
14846
14847 * cppmacro.c (_cpp_builtin_macro_text): Remove unused variable.
14848
3ec5d64d
JDA
148492002-08-07 John David Anglin <dave@hiauly1.hia.nrc.ca>
14850
14851 * configure.in (PREFIX_INCLUDE_DIR): Don't define if prefix and
14852 local_prefix are the same.
14853 * configure: Rebuilt.
14854
ad9335eb
JJ
148552002-08-07 Jakub Jelinek <jakub@redhat.com>
14856 Richard Henderson <rth@redhat.com>
14857
14858 * stor-layout.c (place_union_field): Apply ADJUST_FIELD_ALIGN
14859 to type_align when PCC_BITFIELD_TYPE_MATTERS. Only apply
14860 ADJUST_FIELD_ALIGN if not DECL_USER_ALIGN resp. TYPE_USER_ALIGN.
14861 (place_field): Likewise.
14862 * config/i386/i386.c (x86_field_alignment): Don't check
14863 DECL_USER_ALIGN here.
14864 * config/rs6000/rs6000.c (rs6000_field_alignment): New.
14865 * config/rs6000/rs6000-protos.h (rs6000_field_alignment): New
14866 prototype.
14867 * config/rs6000/rs6000.h (ADJUST_FIELD_ALIGN): Define.
14868 * config/rs6000/aix.h (ADJUST_FIELD_ALIGN): Remove.
14869 * config/rs6000/darwin.h (ADJUST_FIELD_ALIGN): Remove.
14870 * config/rs6000/linux64.h (ADJUST_FIELD_ALIGN): Remove.
14871 * config/rs6000/sysv4.h (ADJUST_FIELD_ALIGN): Remove.
14872 * doc/tm.texi (ADJUST_FIELD_ALIGN): Update description.
14873
0b6f2917
NB
148742002-08-07 Neil Booth <neil@daikokuya.co.uk>
14875
14876 * Makefile.in (c-opts.o, c-common.o, C_AND_OBJC_OBJS): Update.
14877 * c-common.c: Don't include tree-inline.h.
14878 (c_common_init_options, c_common_post_options): Move to c-opts.c.
14879 * c-common.h (c_common_decode_option): New.
14880 * c-decl.c (c_decode_option): Remove.
14881 * c-lang.c (LANG_HOOKS_DECODE_OPTION): Use c_common_decode_option.
14882 * c-opts.c: New file.
14883 * c-tree.h (c_decode_option): Remove.
14884 * doc/passes.texi: Update.
14885 * objc/objc-act.c (objc_decode_option): Remove.
14886 * objc/objc-act.h (objc_decode_option): Remove.
14887 * objc/ojbc-lang.c (LANG_HOOKS_DECODE_OPTION): Use
14888 c_common_decode_option.
14889
e49ec17d
CD
148902002-08-07 Chris Demetriou <cgd@broadcom.com>
14891
14892 * config/mips/mips.md (sunlt_sf, suneq_sf, sunle_sf): Remove
14893 dependency on TARGET_DOUBLE_FLOAT.
14894
ac1ca451
SC
148952002-08-07 Stephen Clarke <stephen.clarke@superh.com>
14896
14897 * config/sh/lib1funcs.asm (GCC_shcompact_incoming_args): Don't
14898 overwrite callee-save registers. Fix comment.
14899
af34e51e
CD
149002002-08-06 Chris Demetriou <cgd@broadcom.com>
14901
14902 * config/mips/mips.c (override_options): Set MASK_BRANCHLIKELY
14903 in target_flags based on ISA, if it was not set on the command
14904 line. Warn if MASK_BRANCHLIKLEY is set but the ISA does not
14905 support Branch Likely instructions.
14906 * config/mips/mips.h (MASK_BRANCHLIKLEY): New macro.
14907 (TARGET_BRANCHLIKELY): Likewise.
14908 (TARGET_SWITCHES): Add -mbranch-likely and -mno-branch-likely.
14909 (GENERATE_BRANCHLIKELY): Use TARGET_BRANCHLIKELY rather than
14910 ISA_HAS_BRANCHLIKELY.
14911 (ISA_HAS_BRANCHLIKELY): Do not include MIPS16 check.
14912 * doc/invoke.texi: Document new MIPS -mbranch-likely and
14913 -mno-branch-likely options.
14914
2631af95
KG
149152002-08-06 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
14916
f538618e
KG
14917 * ip2k.c (ip2k_set_compare): Add missing iteration variable.
14918
2631af95
KG
14919 * Makefile.in (dummy-conditions.o): Depend on $(HCONFIG_H) not
14920 $(GCONFIG_H).
14921
1ae0ccb6
AH
149222002-08-06 Aldy Hernandez <aldyh@redhat.com>
14923
8537ed68
ZW
14924 * c-decl.c (duplicate_decls): Error out for incompatible TLS
14925 declarations.
1ae0ccb6 14926
8537ed68 14927 * testsuite/gcc.dg/tls/diag-3.c: New.
1ae0ccb6 14928
8d3e27d1 149292002-08-06 Dale Johannesen <dalej@apple.com>
db4c55f6 14930
8d3e27d1 14931 * c-common.c (fname_decl): Use line number 0 for
8537ed68 14932 __func__, to avoid confusing debuggers.
8d3e27d1 14933
8b219a76
NS
149342002-08-06 Nathan Sidwell <nathan@codesourcery.com>
14935
14936 * gcov.c: Tidy.
14937 (struct line_info, struct coverage): New structures.
14938 (gcov_file_name, gcov_file): Remove globals.
14939 (output_data): Take source file parameter. Fix memory leak. Break
14940 up into ...
14941 (init_line_info, output_line_info, make_gcov_file_name,
14942 accumulate_branch_counts): ... here.
14943 (calculate_branch_probs, function_summary): Adjust.
14944 (main): Adjust.
14945 (function_*): Remove global variables.
14946
317e98c0
NB
149472002-08-06 Neil Booth <neil@daikokuya.co.uk>
14948
14949 * dwarf2out.c: Remove unused macros.
14950
81d41e74
NB
149512002-08-06 Neil Booth <neil@daikokuya.co.uk>
14952
14953 * function.c (TRAMPOLINE_ALIGNMENT): Always defined.
14954
58551c23
NB
149552002-08-06 Neil Booth <neil@daikokuya.co.uk>
14956
14957 * cppinit.c (struct lang_flags): Rename trigraphs std.
14958 (set_lang): Update.
14959 * cpplib.h (struct cpp_options): New member std.
14960 * cppmacro.c (_cpp_builtin_macro_text): Use std.
14961 (collect_args): Flag whether to swallow a possible future
14962 comma pasted with varargs.
14963 (replace_args): Use this flag.
14964 * doc/cpp.texi: Update varargs extension documentation.
14965
daeabcd0
JJ
149662002-08-06 Jakub Jelinek <jakub@redhat.com>
14967
14968 * config/i386/mmintrin.h (__m64): Make the type 64-bit aligned.
14969
39e3a681
JJ
149702002-08-06 Jakub Jelinek <jakub@redhat.com>
14971
9812691e
JJ
14972 * config/i386/i386.c (x86_field_alignment): Apply min for all MODE_INT
14973 and MODE_CLASS_INT modes.
39e3a681 14974
609a87f3
JJ
149752002-08-06 Jakub Jelinek <jakub@redhat.com>
14976
14977 * config.gcc (*-*-linux*): Default to --enable-threads=posix if no
14978 --{enable,disable}-threads is given to configure.
14979 (alpha*-*-linux*, hppa*-*-linux*, i[34567]86-*-linux*,
14980 x86_64-*-linux*, ia64*-*-linux*, m68k-*-linux*, mips*-*-linux*,
14981 powerpc-*-linux-gnualtivec*, powerpc-*-linux*, s390-*-linux*,
14982 s390x-*-linux*, sh-*-linux*, sparc-*-linux*, sparc64-*-linux*):
14983 Remove thread_file setting here.
14984
ff4c5e7b
DE
149852002-08-06 David Edelsohn <edelsohn@gnu.org>
14986
14987 * doc/install.texi (Binaries): Update Bull Freeware URL.
14988
54f3aa9e
GP
149892002-08-06 Gerald Pfeifer <pfeifer@dbai.tuwien.ac.at>
14990
14991 * doc/gcc.texi (Top): Rename Index to Keyword Index.
14992
d19202ba
NS
149932002-08-05 Nathan Sidwell <nathan@codesourcery.com>
14994
14995 * gcov.c (output_data): Round to % to nearest, tweak formatting.
14996
1bed5ee3
JJ
149972002-08-05 Jakub Jelinek <jakub@redhat.com>
14998
14999 * fold-const.c (associate_trees): Only optimize NEGATE_EXPR in one
15000 of the operands into MINUS_EXPR if code is PLUS_EXPR.
15001
84512347
DR
150022002-08-05 Douglas B Rupp <rupp@gnat.com>
15003
15004 * config.gcc (i[34567]86-*-interix*): Replace interix.o with winnt.o
15005 * config/i386/i386-interix.h (TARGET_NOP_FUN_DLLIMPORT,
15006 drectve_section): Define.
15007 * config/i386/t-interix: Replace interix.o rule with winnt.o.
15008 * config/i386/interix.c: Remove.
15009
b835f6f1
GK
150102002-08-05 Geoffrey Keating <geoffk@redhat.com>
15011
15012 * attribs.c: Don't include obstack.h.
15013 * builtins.c: Likewise.
15014 * cfganal.c: Likewise.
15015 * cfgbuild.c: Likewise.
15016 * cfgcleanup.c: Likewise.
15017 * emit-rtl.c: Likewise.
15018 * loop.c: Likewise.
15019 * stmt.c: Likewise.
15020
15021 * Makefile.in (s-gtype): Re-add dependency on $(GTFILES).
15022
fd291392
GDR
150232002-08-05 Gabriel Dos Reis <gdr@nerim.net>
15024
15025 * doc/c-tree.texi (Expression trees): Document VA_ARG_EXPR
15026
054b7507
CD
150272002-08-04 Chris Demetriou <cgd@broadcom.com>
15028
15029 * doc/invoke.texi: Remove duplicated paragraph describing
15030 TARGET_SWITCHES.
15031
6d9f628e
GK
150322002-08-04 Geoffrey Keating <geoffk@redhat.com>
15033
15034 * Makefile.in (sdbout.o): Doesn't need $(OBSTACK_H).
15035 * collect2.h (permanent_obstack): Delete declaration.
15036 * collect2.c (permanent_obstack): Delete definition.
4912a07c 15037 (main): Don't initialize permanent_obstack. Use xstrdup instead.
6d9f628e
GK
15038 * expr.c: Don't include obstack.h.
15039 (permanent_obstack): Delete declaration.
15040 * function.c: Don't include obstack.h.
15041 (permanent_obstack): Delete declaration.
15042 * integrate.c: Don't include obstack.h.
15043 (function_maybepermanent_obstack): Delete declaration.
15044 * print-tree.c (debug_tree): Use x*alloc not permalloc.
15045 * sdbout.c (gen_fake_label): Use x*alloc not permalloc.
15046 * tlink.c (pfgets): Use xstrdup not permanent_obstack.
15047 * toplev.c (lang_independent_init): Rename init_obstacks to init_ttree.
15048 * tree.h: Rename init_obstacks to init_ttree. Remove declarations
15049 of permalloc, expralloc, perm_calloc.
15050 * tree.c (permanent_obstack): Delete definition.
15051 (init_ttree): Rename from init_obstacks.
15052 (permalloc): Delete.
15053 (perm_calloc): Delete.
15054 (dump_tree_statistics): Don't print information about
15055 permanent_obstack.
15056 * varasm.c (assemble_start_function): Use xstrdup instead of
15057 permalloc/strcpy.
15058 (assemble_variable): Likewise.
15059 * config/alpha/alpha.c (unicosmk_need_dex): Use xmalloc instead of
15060 permalloc.
15061 (unicosmk_add_extern): Likewise.
15062 * config/c4x/c4x.c (c4x_external_ref): Likewise.
15063 (c4x_global_label): Likewise.
15064 * config/frv/frv.c (frv_encode_section_info): Likewise.
15065 * config/i386/winnt.c (i386_pe_record_external_function): Likewise.
15066 (i386_pe_record_exported_symbol): Likewise.
15067 * config/mips/mips.c (mips_output_external): Likewise.
15068 (mips_output_external_libcall): Likewise.
15069 * config/pa/pa.c: (permanent_obstack): Delete declaration.
15070 (output_call): Use ggc_strdup instead of allocating on
15071 permanent_obstack.
15072 * config/romp/romp.c: Include ggc.h.
15073 (get_symref): Don't declare permanent_obstack, use ggc_strdup
15074 intead of permanent_obstack.
15075 * config/rs6000/aix31.h (ASM_OUTPUT_EXTERNAL): Use concat
15076 instead of permalloc.
15077 * config/rs6000/rs6000.c (rs6000_gen_section_name): Use xmalloc
15078 instead of permalloc
15079 * config/rs6000/xcoff.h (ASM_OUTPUT_EXTERNAL): Use concat
15080 instead of permalloc.
15081 * config/vax/vax.c (vms_check_external): Use xmalloc instead of
15082 permalloc.
15083
36a05131
BS
150842002-08-04 Bernd Schmidt <bernds@redhat.com>
15085
15086 Contribute a port developed primarily by Michael Meissner,
15087 Catherine Moore, and Richard Sandiford <rsandifo@redhat.com>.
15088 * config.gcc: Add frv-elf target.
15089 * config/frv/cmovd.c: New file.
15090 * config/frv/cmovh.c: New file.
15091 * config/frv/cmovw.c: New file.
15092 * config/frv/frv-abi.h: New file.
15093 * config/frv/frv-asm.h: New file.
15094 * config/frv/frv-modes.def: New file.
15095 * config/frv/frv-protos.h: New file.
15096 * config/frv/frv.c: New file.
15097 * config/frv/frv.h: New file.
15098 * config/frv/frv.md: New file.
15099 * config/frv/frvbegin.c: New file.
15100 * config/frv/frvend.c: New file.
15101 * config/frv/lib1funcs.asm: New file.
15102 * config/frv/media.h: New file.
15103 * config/frv/modi.c: New file.
15104 * config/frv/t-frv: New file.
15105 * config/frv/uitod.c: New file.
15106 * config/frv/uitof.c: New file.
15107 * config/frv/ulltod.c: New file.
15108 * config/frv/ulltof.c: New file.
15109 * config/frv/umodi.c: New file.
15110 * config/frv/xm-frv.h: New file.
86a0cbcb
BS
15111
15112 * config/frv/media.h: Removed again.
15113
37b8715b
NS
151142002-08-04 Nathan Sidwell <nathan@codesourcery.com>
15115
15116 * gcov.c (bb_file_time): New static variable.
15117 (object_directory): May also be object file.
15118 (preserve_paths): New static variable.
15119 (print_usage): Adjust.
15120 (options): Adjust.
15121 (process_args): Adjust.
15122 (open_files): Simplify. Cope when OBJECT_DIRECTORY is an object
15123 file. Find modification date on bb file.
15124 (read_profile): Don't rewind a NULL file.
15125 (format_hwint): New static function.
15126 (function_summary): Use format_hwint.
15127 (output_data): SOURCE_FILE_NAME is never relative to
15128 OBJECT_DIRECTORY. Use format_hwint. Adjust gcov file name
15129 mangling. Adjust output format to make it more machine readable.
15130 * doc/gcov.texi: Document & clarify semantics.
a7701995 15131
d500c5d7
JM
151322002-08-04 Joseph S. Myers <jsm@polyomino.org.uk>
15133
15134 * doc/include/gcc-common.texi (version-GCC): Increase to 3.3.
15135
ea67fe71
NS
151362002-08-04 Nathan Sidwell <nathan@codesourcery.com>
15137
15138 * gcc.c (cc1_options): Pass output file as auxbase when
15139 appropriate.
15140 * profile.c (init_branch_prob): FILENAME has already had ending
15141 stripped.
15142 * final.c (end_final): Likewise.
15143 * toplev.c (aux_base_name): New global.
15144 (compile_file): Pass aux_base_name to init init_branch_prob and
15145 end_final.
15146 (independent_decode_option, case 'a'): New auxinfo options.
15147 (case 'd'): Protect against mising basename.
15148 (do_compile): Initialize aux_base_name.
15149 * toplev.h (aux_base_name): New global.
15150 * doc/invoke.texi: Adjust documentation.
15151
b23c054d
NS
151522002-08-04 Nathan Sidwell <nathan@codesourcery.com>
15153
15154 * config/i386/i386.c (x86_field_alignment): Remove duplicate test
15155 of TARGET_ALIGN_DOUBLE.
15156
04c1334c 151572002-08-04 Gabriel Dos Reis <gdr@nerim.net>
a7701995 15158
04c1334c
GDR
15159 * diagnostic.c (inform): New function.
15160 * diagnostic.h (inform): Declare.
a7701995 15161
e34eaae5
DE
151622002-08-03 David Edelsohn <edelsohn@gnu.org>
15163
15164 * config/rs6000/rs6000.md (movsi_internal1): Add nop mnemonic.
15165 (movhi_internal): Same.
15166 (movqi_internal): Same.
15167 (movdi_internal64): Same.
15168
15169 * config/rs6000/t-ppccomm (MULTILIB_MATCHES_FLOAT): Add mcpu=405.
15170
15171 * config/rs6000/xcoff.h (SKIP_ASM_OP): Define.
15172 (ASM_OUTPUT_SKIP): Use it. SIZE unsigned.
15173 (COMMON_ASM_OP): Define.
15174 (ASM_OUTPUT_ALIGNED_COMMON): Use it. SIZE unsigned.
15175 Use ALIGN parameter.
15176 (LOCAL_COMMON_ASM_OP): Define.
15177 (ASM_OUTPUT_LOCAL): Use it. SIZE unsigned.
15178
e7b489c8
RS
151792002-08-03 Roger Sayle <roger@eyesopen.com>
15180
15181 * builtins.def: Define new builtin functions exp, expf, expl,
15182 log, logf and logl (and their __builtin_* variants).
15183 * optabs.h (enum optab_index): Add new OTI_exp and OTI_log.
15184 Define exp_optab and log_optab.
15185 * optabs.c (init_optans): Initialize exp_optab and log_optab.
15186 * genopinit.c (optabs): Implement exp_optab and log_optab
15187 using exp?f2 and log?f2 patterns.
15188 * builtins.c (expand_builtin_mathfn): Handle BUILT_IN_EXP*
15189 and BUILT_IN_LOG* using exp_optab and log_optab respectively.
15190 (expand_builtin): Ignore the new builtins (and all cos and
15191 sin variants) when not optimizing. Expand new builtins via
15192 expand_builtin_mathfn when flag_unsafe_math_optimizations.
15193
15194 * doc/extend.texi: Document new exp and log builtins.
15195 * doc/md.texi: Document new exp?f2 and log?f2 patterns
15196 (and previously undocumented cos?f2 and sin?f2 patterns).
15197
de8920be
JM
151982002-08-03 Jason Merrill <jason@redhat.com>
15199
15200 * explow.c (int_expr_size): New fn.
15201 * expr.c (expand_expr) [CONSTRUCTOR]: Use it.
15202 * expr.h: Declare it.
15203
ba462c8e
KW
152042002-08-02 Krister Walfridsson <cato@df.lth.se>
15205
15206 * Makefile.in (gengtype-lex.o, gengtype-yacc.o): Add path to
15207 gengtype-* dependencies.
15208
2017ed61
EC
152092002-08-02 Eric Christopher <echristo@redhat.com>
15210
15211 * config.gcc (mips*-*-linux*): Fix ordering of tm_file.
15212 * config/mips/mips.h (READONLY_DATA_SECTION_ASM_OP): Change
15213 #ifndef to #undef.
15214 (TARGET_MEM_FUNCTIONS): Define instead of define to 1.
15215
055dd007
DE
152162002-08-02 David Edelsohn <edelsohn@gnu.org>
15217
15218 PR optimize/7067
15219 * config/rs6000/rs6000.h (RTX_COSTS): Artificially make MULT
15220 small if optimizing for size.
15221
771a2a66
DJ
152222002-08-02 Daniel Jacobowitz <drow@mvista.com>
15223
15224 * configure.in (FORBUILD): Use $build_alias.
15225 * configure: Regenerated.
15226
ac8ab9fe
RS
152272002-08-02 Richard Sandiford <rsandifo@redhat.com>
15228
15229 * config.gcc: Don't include mips/abi64.h in $tm_file.
15230 * hard-reg-set.h (call_really_used_regs): Declare.
15231 * config/mips/abi64.h: Remove file.
15232 * config/mips/linux.h,
15233 * config/mips/iris6.h: Don't include it.
15234 * config/mips/mips-protos.h (mips_conditional_register_usage): Declare.
15235 * config/mips/mips.h (CONDITIONAL_REGISTER_USAGE): Use it.
15236 (REG_PARM_STACK_SPACE, STACK_BOUNDARY, STRICT_ARGUMENT_NAMING,
15237 FUNCTION_ARG_PASS_BY_REFERENCE, FUNCTION_ARG_PADDING,
15238 FUNCTION_ARG_CALLEE_COPIES, MUST_PASS_IN_STACK, MIPS_STACK_ALIGN):
15239 Bring across definitions from abi64.h.
15240 (GP_ARG_LAST, FP_ARG_LAST): Use MAX_ARGS_IN_REGISTERS.
15241 (BIGGEST_MAX_ARGS_IN_REGISTERS): New.
15242 (struct mips_args): Use it.
15243 * config/mips/mips.c (mips_conditional_register_usage): Define.
15244
a77a9a18
JM
152452002-08-02 Jason Merrill <jason@redhat.com>
15246
15247 * langhooks-def.h (LANG_HOOKS_EXPR_SIZE): New macro.
15248 * langhooks.c (lhd_expr_size): Define default.
15249 * langhooks.h (struct lang_hooks): Add expr_size.
15250 * explow.c (expr_size): Call it.
15251 * expr.c (store_expr): Don't copy an expression of size zero.
15252 (expand_expr) [CONSTRUCTOR]: Use expr_size to calculate how much
15253 to store.
15254 * Makefile.in (builtins.o): Depend on langhooks.h.
15255
a6be5aee
KG
152562002-08-02 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
15257
15258 * Makefile.in (ra-debug.o): Depend on $(TM_P_H).
15259 * ra-debug.c: Include "tm_p.h".
15260 * ra-rewrite.c (is_partly_live_1): Change return type to bool.
15261
e3e16ee3
TM
152622002-08-02 Toon Moene <toon@moene.indiv.nluug.nl>
15263
15264 * simplify-rtx.c (simplify_binary_operation): x * 1 is allowed
15265 when not honoring signalling NaNs.
15266 (simplify_ternary_operation): a == b has a definite value
15267 when not honoring NaNs.
15268
b9d8832d
JM
152692002-08-02 Jason Merrill <jason@redhat.com>
15270
15271 * gdbinit.in (pct): New macro.
15272
825abef4
SS
152732002-08-01 Stan Shebs <shebs@apple.com>
15274 Andreas Tobler <toa@pop.agri.ch>
15275
15276 * ginclude/stddef.h (_BSD_SIZE_T_DEFINED_): Define if not defined,
15277 plays nice with Darwin headers.
bf2e488f 15278 (_BSD_RUNE_T_DEFINED_): Likewise.
825abef4 15279
56da7207
ZW
152802002-08-01 Zack Weinberg <zack@codesourcery.com>
15281
15282 * c-common.c (c_common_init): -Wtraditional also implies -Wlong-long.
15283 * cppinit.c (cpp_post_options): Likewise.
15284
15285 * cppexp.c (cpp_classify_number): Suppress -Wtraditional
15286 warning about 'LL' suffix (but not 'ULL' etc) when
15287 -Wno-long-long is in effect.
15288
15289 * cppmacro.c (_cpp_builtin_macro_text) [BT_TIME, BT_DATE]:
15290 Check for failing time()/localtime(), issue a warning, and
15291 make __TIME__ and __DATE__ expand to fallback strings.
15292
15293 * doc/cpp.texi, doc/extend.texi: Document behavior of __DATE__
15294 and __TIME__ when the date and time cannot be determined.
15295
f4857b9b
AM
152962002-08-02 Alan Modra <amodra@bigpond.net.au>
15297
15298 * config/rs6000/rs6000.c (output_cbranch): Hint differently for power4.
15299
77ca7b2e
DJ
153002002-08-01 Daniel Jacobowitz <drow@mvista.com>
15301
15302 * Makefile.in ($(BUILD_PREFIX_1)ggc-none.o): Use $(GGC_H).
15303
5b552f76
CD
153042002-08-01 Chris Demetriou <cgd@broadcom.com>
15305
15306 * config.gcc (mipsisa64sb1-*-elf*): New configuration.
15307 (mipsisa64sb1el-*-elf*): Likewise.
15308 * config/mips/mips.c (mips_cpu_info_table): Add sb1.
15309 * config/mips/mips.h (processor_type): Add PROCESSOR_SB1.
15310 (TARGET_SB1, TUNE_SB1): New macros.
15311 * doc/invoke.texi: Add sb1 to documentation for MIPS -march and
15312 -mtune flags.
15313
54fbf6a1
DE
153142002-08-01 David Edelsohn <edelsohn@gnu.org>
15315
15316 * varasm.c (asm_emit_uninitialized): Return false if global BSS
15317 and ASM_EMIT_BSS not supported by target.
15318 (assemble_variable): Do not duplicate uninitialized logic.
15319 Fall through if asm_emit_uninitialized failed.
15320
3d16b407
CD
153212002-08-01 Chris Demetriou <cgd@broadcom.com>
15322
15323 * config/mips/mips.h (BRANCH_LIKELY_P): Remove unused macro.
15324
fb52d8de
AM
153252002-08-02 Alan Modra <amodra@bigpond.net.au>
15326
80926cc1
AM
15327 * config/rs6000/linux64.h (DBX_OUTPUT_BRAC): Define.
15328 (DBX_OUTPUT_LBRAC, DBX_OUTPUT_RBRAC): Define.
15329
fb52d8de
AM
15330 * config/rs6000/rs6000.c (output_toc): Don't use lshift_double when
15331 HOST_BITS_PER_WIDE_INT == 64.
15332
a4b5414c
KG
153332002-08-01 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
15334
15335 * df.c (df_insn_table_realloc): Change parameter to unsigned.
15336 * optabs.c (expand_binop): Make variable unsigned.
15337 * simplify-rtx.c (simplify_subreg): Likewise.
15338 * unroll.c (unroll_loop): Cast to avoid signed/unsigned warnings.
15339
a03e67c3
FS
153402002-08-01 Franz Sirl <Franz.Sirl-kernel@lauterbach.com>
15341
15342 * c-common.c (cb_register_builtins): Always define __GXX_ABI_VERSION.
15343
de273d3f
RH
153442002-08-01 Richard Henderson <rth@redhat.com>
15345
56da7207 15346 * toplev.c (parse_options_and_default_flags): Don't set
de273d3f
RH
15347 flag_reorder_blocks for -Os.
15348
15349 * config/avr/avr.c (avr_optimization_options): Remove.
15350 * config/avr/avr.h (OPTIMIZATION_OPTIONS): Remove.
15351 * config/m68hc11/m68hc11.c (m68hc11_optimization_options): Remove.
15352 * config/m68hc11/m68hc11.h (OPTIMIZATION_OPTIONS): Remove.
15353
4e4d733e
L
153542002-08-01 H.J. Lu <hjl@gnu.org>
15355 Richard Henderson <rth@redhat.com>
15356
15357 * output.h (DECL_READONLY_SECTION): Remove.
15358 (decl_readonly_section): Declare.
15359 * varasm.c (decl_readonly_section): New.
15360 (default_section_type_flags, default_select_section): Use it.
15361 * config/arm/pe.c (arm_pe_unique_section): Likewise.
15362 * config/i386/interix.c (i386_pe_unique_section): Likewise.
15363 * config/i386/winnt.c (i386_pe_unique_section): Likewise.
15364 * config/mcore/mcore.c (mcore_unique_section): Likewise.
15365 * config/mips/mips.c (mips_unique_section): Likewise.
15366
32e9b960
RH
153672002-08-01 Richard Henderson <rth@redhat.com>
15368
15369 * integrate.c (copy_rtx_and_substitute): Squash MEM_EXPR when it
15370 refers to a subroutine parameter.
15371
81e602b5
JJ
153722002-08-01 Jakub Jelinek <jakub@redhat.com>
15373
15374 * varasm.c (assemble_visibility): Strip name encoding.
15375
ac14c725
ID
153762002-08-01 Ian Dall <ian@sibyl.beware.dropbear.id.au>
15377
15378 * config/ns32k/ns32k.h (TARGET_IEEE_COMPARE): Correct earlier patch.
15379 (RETURN_ADDR_RTX): Cannot determine return address for FRAME > 0
15380 when there is no frame pointer.
15381 (INITIAL_FRAME_POINTER_OFFSET): Count stack space for saved fp
15382 registers properly.
15383 * config/ns32k/__unorddf2.c: New file.
15384 * config/ns32k/__unordsf2.c: New file.
15385 * config/ns32k/t-ns32k: New file.
15386 * config.gcc (ns32k-*-netbsd*): Use it.
15387
17072732
AH
153882002-08-01 Aldy Hernandez <aldyh@redhat.com>
15389
15390 * config/rs6000/rs6000.h (SPU_CONST_OFFSET_OK): Change to 0xff.
15391
c288218a
NB
153922002-08-01 Neil Booth <neil@daikokuya.co.uk>
15393
15394 * c-common.c (__GXX_ABI_VERSION): Correct spelling.
15395
43bfc248
BK
153962002-08-01 Benjamin Kosnik <bkoz@redhat.com>
15397
15398 * c-common.c (cb_register_builtins): Set __GXX_ABI_VERSION__ to 102.
15399
479f2cea
RS
154002002-08-01 Richard Sandiford <rsandifo@redhat.com>
15401
15402 * config/mips/mips.md: Add [!]TARGET_MIPS16 to sgtu conditions.
15403
02280659
ZD
154042002-08-01 Zdenek Dvorak <rakdver@atrey.karlin.mff.cuni.cz>
15405
15406 * gcse.c (expr_hash_table_size, n_exprs, set_hash_table_size,
15407 n_sets): Removed.
15408 (expr_hash_table, set_hash_table): Type changed to ...
15409 (struct hash_table): New type.
15410 (hash_scan_insn, hash_scan_set, hash_scan_clobber, hash_scan_call,
15411 insert_expr_in_table, insert_set_in_table, compute_hash_table,
15412 dump_hash_table, lookup_expr, lookup_set, compute_local_properties,
15413 compute_ae_gen, compute_ae_kill): Modified to pass the table explicitly.
15414 (alloc_set_hash_table, alloc_expr_hash_table): Merged to ...
15415 (alloc_hash_table): New.
15416 (free_set_hash_table, free_expr_hash_table): Merged to ...
15417 (free_hash_table): New.
15418 (compute_set_hash_table, compute_expr_hash_table): Merged to ...
15419 (compute_hash_table_work): New.
15420 (classic_gcse, one_classic_gcse_pass, compute_cprop_data,
15421 find_avail_set, one_cprop_pass, find_bypass_set, compute_pre_data,
15422 pre_edge_insert, pre_insert_copies, pre_delete, pre_gcse,
15423 one_pre_gcse_pass, compute_transpout, compute_code_hoist_vbeinout,
15424 hoist_code, one_code_hoisting_pass,
15425 trim_ld_motion_mems): Altered due to changed type of hash tables.
15426
905173eb
ZW
154272002-08-01 Zack Weinberg <zack@codesourcery.com>
15428
15429 * final.c (output_alternate_entry_point):
15430 If ASM_OUTPUT_TYPE_DIRECTIVE is defined, use it.
15431
83321d36
KG
154322002-08-01 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
15433
ad0f1765
KG
15434 * objc/objc-act.c (encode_complete_bitfield): Add prototype and
15435 avoid ISO C style function definition.
15436
83321d36
KG
15437 * expr.c (expand_assignment): Delete unused variable.
15438
73e42cf3
TM
154392002-08-01 Toon Moene <toon@moene.indiv.nluug.nl>
15440
15441 * c-common.c (cb_register_builtins): Set
15442 __FINITE_MATH_ONLY__ to 1 if -ffinite-math-only
15443 is given, and to 0 otherwise.
15444 * combine.c (simplify_if_then_else): HONOR_NANS
15445 implies FLOAT_MODE_P.
15446
78df51fe
NB
154472002-08-01 Neil Booth <neil@daikokuya.co.uk>
15448
15449 * cppinit.c (COMMAND_LINE_OPTIONS): Remove OPT_dollar.
15450 (cpp_handle_option): Don't handle it.
15451 (print_help): Update.
15452 * doc/cppopts.texi: Update.
15453
abecfc8f
NB
154542002-08-01 Neil Booth <neil@daikokuya.co.uk>
15455
15456 * c-common.c (cb_register_builtins): If C++, define
15457 __EXCEPTIONS, __DEPRECATED and __GXX_ABI_VERSION as appropriate.
15458 * gcc.c (cpp_unique_options): Remove __GXX_ABI_VERSION.
15459cp:
15460 * lang-specs.h: Simplify in accordance with new code in
15461 c-common.c.
15462
4078b403
NB
154632002-08-01 Neil Booth <neil@daikokuya.co.uk>
15464
15465 * c-common.c: Define all C/ObjC/C++ warning and flag variables.
15466 * c-common.h: Declare all C/ObjC/C++ warning and flag variables.
15467 * c-decl.c: Move all warning and flag variables to c-common.c.
15468 * c-format.c: Move all warning variables to c-common.c.
15469 * c-tree.h: Move all warning and flag declarations to c-common.h.
15470 * objc/objc-act.c: Move all warning variables to c-common.c.
15471 (flag_warn_protocol): Rename warn_protocol.
15472
692f5611
JDA
154732002-07-31 John David Anglin <dave@hiauly1.hia.nrc.ca>
15474
15475 * pa-linux.h (GLOBAL_ASM_OP): Fix typo.
15476
c7a009a2 154772002-07-31 Graham Stott <graham.stott@btinternet.com>
480e7ded 15478
905173eb 15479 * config/stormy16/stormy16.h (BSS_SECTION_ASM_OP): Add missing
480e7ded
GS
15480 .section prefix.
15481
b069de3b
SS
154822002-07-31 Stan Shebs <shebs@apple.com>
15483
15484 * config.gcc (i[34567]86-*-darwin*): New configuration.
15485 * config/darwin.h (TARGET_ENCODE_SECTION_INFO): Undefine before
15486 defining.
15487 (TARGET_ENCODE_SECTION_INFO): Ditto.
15488 (ASM_PREFERRED_EH_DATA_FORMAT): Ditto.
15489 * config/darwin.c (machopic_indirect_data_reference): Remove
15490 setting of RTX_UNCHANGING_P.
15491 (machopic_legitimize_pic_address): Move RTX_UNCHANGING_P up so as
15492 not to be applied to sums.
15493 * config/i386/t-darwin: New file.
15494 * config/i386/darwin.h: New file.
15495 * config/i386/i386.h (TARGET_MACHO): Add default definition.
15496 * config/i386/i386.md (tablejump): Add TARGET_MACHO case.
15497 * config/i386/i386.c (output_set_got): For Mach-O, output Mach-O
15498 label and not the GOT add.
15499 (constant_address_p): For Mach-O, seeing a CONST is enough.
15500 (legitimate_pic_address_disp_p): Add a Mach-O case.
15501 (legitimate_address_p): Also test machopic_operand_p if Mach-O.
15502 (legitimize_pic_address): Use generic Mach-O code to legitimize.
15503 (output_pic_addr_const): Suppress @PLT if Mach-O, and parens
15504 if outputting a difference.
15505 (ix86_output_addr_diff_elt): Add Mach-O case.
15506 (ix86_expand_move): Similarly.
15507 (ix86_expand_call): Similarly.
15508 (current_machopic_label_num): New global.
15509 (machopic_output_stub): New function.
15510 (ix86_value_regno): New function.
15511 (ix86_function_value): Use it instead of VALUE_REGNO.
15512 (ix86_libcall_value): Ditto.
15513 * config/i386/unix.h (VALUE_REGNO): Remove.
15514
1de4ecb6
GS
155152002-07-31 Graham Stott <grahas@btinternet.com>
15516
15517 * config/rs6000/rs6000.c(rs6000_hash_constant): Fix
905173eb 15518 hash for LABEL_REF's.
1de4ecb6 15519
23368455
GS
155202002-07-31 Graham Stott <grahams@btinternet.com>
15521
15522 * config/rs6000/rs6000.c (spe_init_builtins,
15523 altivec_init_builtins, rs6000_common_init_builtins):
905173eb 15524 Replace ANSI with K&R function def.
23368455 15525
ad72b533
DE
155262002-07-31 David Edelsohn <edelsohn@gnu.org>
15527
15528 * rs6000.c (validate_condition_mode): Test flag_finite_math_only
15529 for CCFPmode.
15530
302359da
RS
155312002-07-31 Richard Sandiford <rsandifo@redhat.com>
15532
15533 * config/mips/crtn.asm: Don't use __mips16 to determine the
15534 return-address offset. Define RA to a suitable temporary
15535 register for the return address.
15536
ead0c1d5
RS
155372002-07-31 Richard Sandiford <rsandifo@redhat.com>
15538
15539 * config/mips/mips.md (eh_set_lr_si, eh_set_lr_di): Change
15540 constraints to 'd'.
15541
3fb9d48a
CD
155422002-07-30 Chris Demetriou <cgd@broadcom.com>
15543
15544 * config/mips/elf.h (STARTFILE_SPEC): Define differently if
15545 default ABI is MEABI. (Undoes incorrect change in Eric Christopher's
15546 patch on 2002-07-29.)
15547 * config/mips/elf64.h (STARTFILE_SPEC): Likewise.
15548
072cdaed
KG
155492002-07-30 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
15550
506a61b1
KG
15551 * alpha.h, arc.h, arm/aout.h, avr.h, cris.h, d30v.h, dsp16xx.h,
15552 fr30.h, h8300.h, i370.h, i386/sco5.h, i386/unix.h, i960.h, ia64.h,
15553 ip2k.h, m32r.h, mcore.h, mips.h, mn10200.h, mn10300.h, ns32k.h,
15554 openbsd.h, pa/pa-linux.h, pdp11.h, romp.h, rs6000/sysv4.h,
15555 s390/linux.h, sh.h, sparc.h, stormy16.h, v850.h, vax.h, xtensa.h:
15556 (ASM_GLOBALIZE_LABEL): Delete.
15557 (GLOBAL_ASM_OP): Define.
15558
072cdaed 15559 * m68hc11.h, m68k.h, m88k.h (ASM_GLOBALIZE_LABEL): Delete.
905173eb 15560
072cdaed
KG
15561 * defaults.h (ASM_GLOBALIZE_LABEL): Provide a default.
15562 * doc/tm.texi (ASM_GLOBALIZE_LABEL): Update docs.
15563
6fd14075
GK
155642002-07-30 Geoffrey Keating <geoffk@redhat.com>
15565
15566 * doc/extend.texi (Hints implementation): Document that GCC
15567 mostly ignores `register'.
15568
2e8f2e8f
TM
155692002-07-30 Toon Moene <toon@moene.indiv.nluug.nl>
15570
15571 * flags.h: Declare flag_finite_math_only.
15572 Use it in definition of HONOR_NANS and
15573 HONOR_INFINITIES.
15574 * c-common.c (cb_register_builtins): Emit
15575 __FINITE_MATH_ONLY__ when flag_finite_math_only
15576 is set.
15577 * combine.c (simplify_if_then_else): If
15578 flag_finite_math_only is set, a == b has a
15579 definite value.
15580 * toplev.c: Initialize flag_finite_math_only.
15581 (set_flags_fast_math): Set it on -ffast-math.
15582 (flag_fast_math_set_p): Test it.
15583 * doc/invoke.texi: Document -ffinite-math-only.
15584
a538e580
RH
155852002-07-30 Richard Henderson <rth@redhat.com>
15586
15587 * ifcvt.c (noce_get_alt_condition): Use reg_overlap_mentioned_p.
15588 (noce_process_if_block): Likewise.
15589
26e20555
BS
155902002-07-30 Bernd Schmidt <bernds@redhat.com>
15591
15592 * ifcvt.c (cond_exec_process_if_block): Fix a merging error.
15593 Bail out early if false_expr is NULL and we'd crash due to this.
79cbc1f7
BS
15594 * genemit.c (gen_expand): Recognize return insns even if the return
15595 appears in a parallel.
d8088c6f
BS
15596 * libgcc2.c: Expand macro DECLARE_LIBRARY_RENAMES if it is defined.
15597 * config/fp-bit.c: Likewise.
15598 * doc/tm.texi: Document it.
905173eb 15599
0559cc77
DE
156002002-07-30 David Edelsohn <edelsohn@gnu.org>
15601 Zack Weinberg <zack@codesourcery.com>
15602
15603 * rs6000.c (rs6000_expand_unop_builtin): Check icode not
15604 CODE_FOR_nothing. Change switch to if.
15605 (rs6000_expand_binop_builtin): Same.
15606 (rs6000_expand_builtin): Expand builtin if target support enabled.
15607 (rs6000_init_builtins): Init builtin if target support enabled.
15608 (rs6000_common_init_builtins): Check icode not CODE_FOR_nothing.
15609
60b8aa94
FS
156102002-07-30 Franz Sirl <Franz.Sirl-kernel@lauterbach.com>
15611
15612 * gcc.c (cpp_unique_options): Define __GXX_ABI_VERSION, bump it to 101.
15613
714fb710
RS
156142002-07-30 Richard Sandiford <rsandifo@redhat.com>
15615
15616 * config/mips/mips.h (SUBTARGET_ASM_DEBUGGING_SPEC): Fix typo.
15617
c608a684
R
15618Tue Jul 30 18:31:31 2002 J"orn Rennecke <joern.rennecke@superh.com>
15619
15620 * sh.md (cond_delay_slot): New attribute.
15621 (cbranch delay): Use it for anulled-true case.
15622 (stuff_delay_slot): New pattern.
15623 * sh.c (print_operand, case '.'): Don't print .s / /s fore zero-length
15624 delay slot insn.
15625 (gen_far_branch): Emit stuff_delay_slot pattern.
15626
0a756401
R
15627Tue Jul 30 11:21:44 2002 J"orn Rennecke <joern.rennecke@superh.com>
15628
15629 * unroll.c (copy_loop_body): Don't copy NOTE_INSN_LOOP_CONT.
15630
68e82b83
KH
156312002-07-30 Kazu Hirata <kazu@cs.umass.edu>
15632
15633 * fold-const.c: Fix comment typos.
15634 * gcse.c: Likewise.
15635 * reload1.c: Likewise.
15636
fe6b547a
AH
156372002-07-29 Aldy Hernandez <aldyh@redhat.com>
15638
15639 * config/rs6000/rs6000.md: Disallow CCEQ compare with crnor/crnot
15640 for TARGET_SPE.
15641
7ff4a7ef
GDR
156422002-07-30 Gabriel Dos Reis <gdr@nerim.net>
15643
15644 * c-pretty-print.h (pp_c_statement): Declare.
15645 * c-pretty-print.c (pp_c_postfix_expression): #if 0 support for SRCLOC.
15646 (pp_c_statement): Define.
15647
4ad5e05d
KG
156482002-07-30 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
15649
15650 * alpha.h, arc.h, arm/aout.h, avr.h, c4x.h, cris.h, d30v.h,
15651 darwin.h, dsp16xx.h, fr30.h, h8300.h, i370.h, i386.h, i960.h,
15652 ip2k.h, m32r.h, m68hc11.h, m68k.h, m88k.h, mcore.h, mips.h,
15653 mn10200.h, mn10300.h, ns32k.h, pa/pa-linux.h, pdp11.h, romp.h,
15654 rs6000/sysv4.h, s390/linux.h, sh.h, sparc.h, stormy16.h,
15655 v850.h, vax.h, xtensa.h (ASM_OUTPUT_LABEL): Delete definition.
15656
15657 * defaults.h (ASM_OUTPUT_LABEL): Provide a default.
15658 * doc/tm.texi (ASM_OUTPUT_LABEL): Update docs.
15659
1e6a3e1e
GDR
156602002-07-30 Gabriel Dos Reis <gdr@nerim.net>
15661
15662 * c-pretty-print.c (pp_c_primary_expression): Handle STMT_EXPR.
15663 (pp_c_postfix_expression): Handle ARROW_EXPR, FFS_EXPR,
15664 COMPOUND_LITERAL_EXPR, VA_ARG_EXPR.
15665 (pp_c_expression): Update.
15666
1dcd444b
KG
156672002-07-29 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
15668
15669 * alpha/vms-cc.c (preprocess_args, main): Use xstrdup and/or
15670 concat in lieu of xmalloc/strcpy/memcpy/sprintf.
15671 * alpha/vms-ld.c (main): Likewise.
15672 * dsp16xx.c (double_reg_to_memory): Likewise.
15673 * mcore.c (mcore_expand_prolog): Likewise.
15674 * cppfiles.c (read_name_map): Likewise.
15675 * gensupport.c (process_rtx, identify_predicable_attribute,
15676 alter_test_for_insn): Likewise.
15677 * vmsdbgout.c (write_rtnbeg, vmsdbgout_init): Likewise.
15678
e62f4abc
RS
156792002-07-29 Roger Sayle <roger@eyesopen.com>
15680
15681 * builtins.c (expand_builtin): Change the default behavior to
905173eb 15682 only issue an error if the builtin function doesn't have a
e62f4abc
RS
15683 fallback library call. Remove several cases handled by the
15684 new default.
15685
0cd2fb44
JDA
156862002-07-29 John David Anglin <dave@hiauly1.hia.nrc>
15687
15688 * real.c (ieee_24, ieee_53, ieee_64, ieee_113): Define only if the
15689 floating point format of the target is IEEE.
15690 * (dec_f, dec_d, dec_g, dec_h): Define only if the floating point
15691 format of the target is DEC.
15692
b642261e
RH
156932002-07-29 Richard Henderson <rth@redhat.com>
15694
15695 * unroll.c (verify_addresses): Remove.
15696 (find_splittable_givs): Never split DEST_ADDR givs.
15697
cba57c9d
GK
156982002-07-29 Geoffrey Keating <geoffk@redhat.com>
15699
15700 * doc/gty.texi (GGC Roots): Clarify that the list of syntaxes
15701 is exhaustive.
15702 (Files): Improve documentation on generated source files.
15703
15704 * doc/extend.texi (Translation implementation): Document what
15705 diagnostics look like.
15706 (Identifiers implementation): Document that there's normally no
15707 limit on identifier names.
15708 (Integers implementation): Document two's complement.
8d9afc4e 15709 (Hints implementation): Document that GCC honors 'inline', mostly.
cba57c9d
GK
15710 (Preprocessing directives implementation): Document that GCC
15711 requires the current time.
15712
76a8ecba
GDR
157132002-07-30 Gabriel Dos Reis <gdr@nerim.net>
15714
15715 * c-pretty-print.h (struct c_pretty_print_info): Add new member.
15716 (pp_initializer): New macro.
15717 (pp_c_initializer): Declare.
15718 * c-pretty-print.c (pp_c_primary_expression): HAndle TARGET_EXPR.
15719 (pp_c_initializer): Define.
15720 (pp_c_initializer_list): New function.
15721 (pp_c_postfix_expression): Handle ABS_EXPR, COMPLEX_CST,
15722 VECTOR_CST, CONSTRUCTOR.
15723 (pp_c_unary_expression): Handle CONJ_EXPR, REALPART_EXPR,
905173eb 15724 IMAGPART_EXPR.
76a8ecba
GDR
15725 (pp_c_cast_expression): Handle FLOAT_EXPR.
15726 (pp_c_assignment_expression): Handle INIT_EXPR.
15727 (pp_c_expression): Update.
15728
4307be72
NB
157292002-07-30 Neil Booth <neil@daikokuya.co.uk>
15730
15731 * objc/objc-act.c (objc_init): Return immediately if filename
15732 is NULL.
15733
6d439235
EC
157342002-07-29 Eric Christopher <echristo@redhat.com>
15735
905173eb
ZW
15736 * config/mips/elf.h: Remove ecoff.h and gofast includes.
15737 (DWARF2_DEBUGGING_INFO, DBX_DEBUGGING_INFO): Define unconditionally.
15738 (SDB_DEBUGGING_INFO): Undefine.
15739 (PREFERRED_DEBUGGING_TYPE): Set to DWARF2_DEBUG.
6d439235
EC
15740 (PUT_SDB_SIZE): Remove.
15741 (SUBTARGET_ASM_DEBUGGING_SPEC): Redefine.
905173eb
ZW
15742 (STARTFILE_SPEC): Add isa3264 define.
15743 * config/mips/elf64.h: Ditto. Move TARGET_MEM_FUNCTIONS from here...
15744 * config/mips/ecoff.h: Remove. and here...
15745 * config/mips/iris3.h: and here...
15746 * config/mips/sni-svr4.h: and here...
15747 * config/mips/mips.h: To here. Remove OBJECT_FORMAT_ROSE ifdefs.
6d439235
EC
15748 Add assembler -mmdebug options for non-dwarf debugging.
15749 * config/mips/r3900.h: Remove debug info defines.
905173eb
ZW
15750 * config/mips/isa32-linux.h: Remove, move functionality to config.gcc.
15751 * config/mips/isa3264.h: Ditto.
15752 * config/mips/t-isa3264: Fix up for file removal and gofast configure
15753 change.
15754 * config/mips/t-elf: Ditto.
15755 * config/mips/t-ecoff: Ditto.
15756 * config/mips/t-r3900: Ditto.
15757 * config/mips/t-iris5-6: Ditto.
15758 * config/mips/t-isa3264: Ditto.
15759 * config/mips/t-linux: Remove.
15760 * config/mips/t-netbsd: Remove.
15761 * config/mips/t-mips: New file.
15762 * config/mips/t-gofast: Ditto.
15763 * config/mips/netbsd.h: Remove unnecessary undefines.
15764 * config/mips/linux.h: Remove #include of mips.h.
15765 * config.gcc: Add mips.h include for elf targets. Remove tm_file
15766 for ecoff. Add gofast configure option for mips.
6d439235 15767
4357a6c3
CD
157682002-07-29 Chris Demetriou <cgd@broadcom.com>
15769
15770 * configure.in (mips*-*-*): Add a test to see if MIPS libgloss
15771 linker scripts use STARTUP directives consistently.
15772 * configure: Regenerate.
15773 * config.in: Regenerate.
15774 * config/mips/elf.h (STARTFILE_SPEC): Define conditionally, based
15775 on whether HAVE_MIPS_LIBGLOSS_STARTUP_DIRECTIVES is defined.
15776 * config/mips/elf64.h (STARTFILE_SPEC): Likewise.
15777 * config/mips/isa3264.h (STARTFILE_SPEC): Do not redefine if
15778 HAVE_MIPS_LIBGLOSS_STARTUP_DIRECTIVES is set; the result
15779 will be the same.
15780
9a5cd606
AH
157812002-07-29 Aldy Hernandez <aldyh@redhat.com>
15782
15783 * config/rs6000/rs6000.md ("cpu"): Add ppc8540 to attribute.
15784
a23acaa6
AH
157852002-07-29 Aldy Hernandez <aldyh@redhat.com>
15786
15787 * config/rs6000/rs6000.h (RTX_COSTS): Add MULT case for 8540.
15788
10ed84db
AH
157892002-07-29 Aldy Hernandez <aldy@quesejoda.com>
15790
15791 * config/rs6000/rs6000.md: Move altivec patterns from here...
15792
15793 * config/rs6000/altivec.md: ...to here.
15794
c3021e5d
AH
157952002-07-29 Aldy Hernandez <aldyh@redhat.com>
15796
15797 * config/rs6000/spe.md ("spe_evmra"): Change to unspec.
15798
6f1087be
RH
157992002-07-29 Richard Henderson <rth@redhat.com>
15800
15801 * emit-rtl.c (set_mem_attributes_minus_bitpos): Rename from
15802 set_mem_attributes and add BITPOS argument. Subtract it from
15803 OFFSET when same is adjusted.
15804 (set_mem_attributes): New wrapper function.
15805 * expr.c (expand_assignment): Use set_mem_attributes_minus_bitpos;
15806 remove offset adjustment hack.
15807 * expr.h (set_mem_attributes_minus_bitpos): Declare.
15808
61ccbcfd
GDR
158092002-07-29 Gabriel Dos Reis <gdr@nerim.net>
15810
15811 * Makefile.in (C_OBJS): Include c-pretty-print.o
15812 (c-pretty-print.o): Add depency rule.
15813 * pretty-print.h: Add more macros.
15814 * c-pretty-print.c: New file.
15815 * c-pretty-print.h: Likewise.
15816
09101f56
AH
158172002-07-29 Aldy Hernandez <aldyh@redhat.com>
15818
15819 * config/rs6000/spe.h (__internal_ev_mwhgumian): Cast vector
15820 constants to __ev64_s32__.
15821 (__internal_ev_mwhgsmian): Same.
15822 (__internal_ev_mwhgsmfan): Same.
15823 (__internal_ev_mwhgssfan): Same.
15824 (__internal_ev_mwhgumiaa): Same.
15825 (__internal_ev_mwhgsmiaa): Same.
15826 (__internal_ev_mwhgsmfaa): Same.
15827 (__internal_ev_mwhgssfaa): Same.
15828
af673a52
DE
158292002-07-29 David Edelsohn <edelsohn@gnu.org>
15830
15831 * varasm.c (assemble_variable): Narrow test for uninitialized
15832 without BSS target support.
15833
6c208acd
NS
158342002-07-29 Nathan Sidwell <nathan@codesourcery.com>
15835
15836 * profile.c: Add file comment describing the overall algorithm and
15837 structures.
15838 (struct edge_info): Add comments.
15839 (struct bb_info): Add comments.
15840 * basic-block.h (EDGE_*): Add comments.
15841 * doc/gcov.texi (Gcov Data Files): Document bit flags.
15842
624f0d60
BW
158432002-07-29 Bob Wilson <bob.wilson@acm.org>
15844
15845 * config/xtensa/elf.h, config/xtensa/linux.h
15846 (TARGET_OS_CPP_BUILTINS): Define.
15847 (CPP_PREDEFINES): Remove.
15848 * config/xtensa/xtensa.h (TARGET_CPU_CPP_BUILTINS): Define.
15849 (CPP_SPEC): Remove.
15850
2199e5fa
ZW
158512002-07-29 Zack Weinberg <zack@codesourcery.com>
15852
15853 * gensupport.c: Include hashtab.h.
15854 (insn_elision, condition_table, hash_c_test, cmp_c_test,
15855 maybe_eval_c_test): New routines and data structures to
15856 support insn elision.
15857 (init_md_reader): Read and initialize the condition_table.
15858 (read_md_rtx): Discard insn patterns whose C test is provably
15859 always false.
15860 * gensupport.h: Declare new functions and data structures.
15861
15862 * genconditions.c, dummy-conditions.c: New files.
15863 * Makefile.in: Build genconditions; run it to construct
15864 insn-conditions.c; build that and link it into most gen*
15865 programs.
15866 (HOST_SUPPORT, HOST_EARLY_SUPPORT): New variables.
15867 (GEN): Delete, unused.
15868 (STAGESTUFF): Update.
15869
15870 * gencodes.c: (gen_insn): #define CODE_FOR_xxx equal to
15871 CODE_FOR_nothing for all elided patterns.
15872 (main): Tweaked to support this.
15873 * genflags.c (gen_proto): Emit a static inline generator
15874 function here for all elided patterns, which simply returns
15875 NULL_RTX.
15876 (gen_insn): Do not define HAVE_xxx for elided patterns.
15877 (main): Tweaked to support this. No need to forward-declare
15878 struct rtx_def.
15879 * genrecog.c: Do not bother emitting the C test if it's known
15880 to be true at compile time.
15881
6ab185d6
MS
158822002-07-29 Mike Stump <mrs@apple.com>
15883
6d439235 15884 * config.gcc (target_gtfiles): Initialize, as otherwise cross
2199e5fa 15885 compilers hosted on powerpc-apple-darwin6.0 won't even build.
6ab185d6 15886
72b075d1
RE
158872002-07-29 Richard Earnshaw <rearnsha@arm.com>
15888
15889 * arm.md (sibcall, sibcall_value): Add RETURN as part of the pattern,
15890 remove clobber of LR.
15891 (sibcall_insn, sibcall_value_insn): Update accordingly.
15892 (sibcall_epilogue): Remove debugging comment from assembler stream.
15893
f63c45ec
GDR
158942002-07-29 Gabriel Dos Reis <gdr@nerim.net>
15895
15896 * pretty-print.h: Define more macros.
15897 * diagnostic.h (output_formatted_integer): Moved from...
15898 * diagnostic.c: ... here.
15899
c27c15db
KG
159002002-07-28 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
15901
15902 * stormy16.h (ASM_OUTPUT_SYMBOL_REF): Use ASM_OUTPUT_LABEL_REF.
15903
99086d59
ZW
159042002-07-28 Zack Weinberg <zack@codesourcery.com>
15905
15906 * defaults.h (ASM_OUTPUT_MEASURED_SIZE): Take only two
15907 arguments. Always use ".-symbol" as expression argument.
15908 * doc/tm.texi: Update to match. Document requirement for
15909 ".size symbol, .-symbol" to be acceptable to assembler.
15910
15911 * config/elfos.h, config/netbsd-aout.h, config/openbsd.h,
15912 config/arm/elf.h, config/avr/avr.h, config/cris/aout.h,
15913 config/i386/freebsd-aout.h, config/i386/sco5.h,
15914 config/ip2k/ip2k.h, config/m88k/m88k.h, config/xtensa/elf.h,
15915 config/xtensa/linux.h: Update uses of ASM_OUTPUT_MEASURED_SIZE.
15916
dd86aabf
KG
159172002-07-28 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
15918
6fd327e9
KG
15919 * Makefile.in (gengtype-lex.c): Fix error in last change.
15920
8155cedd
KG
15921 * alpha/freebsd.h (TARGET_OS_CPP_BUILTINS): Add missing
15922 backslash.
15923
dd86aabf
KG
15924 * Makefile.in (vmsdbgout.o): Depend on function.h.
15925
15926 * vmsdbgout.c: Include function.h.
15927
d4348177
AM
159282002-07-28 Alan Modra <amodra@bigpond.net.au>
15929
15930 * prefix.c (update_path): Don't strip single `.' path components
15931 unless stripping a later `..' component. Exit loop as soon as
15932 a valid path is found.
15933
c2ef6d34
RS
159342002-07-27 Roger Sayle <roger@eyesopen.com>
15935
15936 * builtins.def [DEF_GCC_BUILTIN]: Require an explicit ATTRS
15937 argument. Mark BUILT_IN_RETURN, BUILT_IN_EH_RETURN,
15938 BUILT_IN_LONGJMP and BUILT_IN_TRAP as noreturn, the ISO C99
15939 floating point unordered comparisons (e.g. __builtin_isgreater)
15940 as const, and leave the remaining GCC_BUILTINs unchanged.
15941
15942 * c-decl.c (builtin_function): No need to explicitly mark
15943 BUILT_IN_RETURN and BUILT_IN_EH_RETURN as noreturn.
15944
52bfebf0
RS
159452002-07-27 Roger Sayle <roger@eyesopen.com>
15946
15947 * Makefile.in: rtlanal.o now depends upon real.h.
15948
15949 * flags.h [flag_signaling_nans]: New flag.
15950 [HONOR_SNANS]: New macro.
15951
15952 * toplev.c [flag_signaling_nans]: Initialize to false.
99086d59 15953 (f_options): Add processing for "-fsignaling-nans".
52bfebf0
RS
15954 (set_fast_math_flags): Clear flag_signaling_nans with -ffast-math.
15955 (process_options): flag_signaling_nans implies flag_trapping_math.
15956
15957 * c-common.c (cb_register_builtins): Define __SUPPORT_SNAN__
15958 when -fsignaling-nans. First step to implementing WG14's N965.
15959
15960 * fold-const.c (fold) [MULT_EXPR]: Conditionalize transforming
15961 1.0 * x into x, and -1.0 * x into -x on !HONOR_SNANS.
15962 [RDIV_EXPR]: Conditionalize x/1.0 into x on !HONOR_SNANS.
15963
15964 * simplify-rtx.c (simplify_relational_operation): Conditionalize
15965 transforming abs(x) < 0.0 into false on !HONOR_SNANS.
15966
15967 * rtlanal.c: #include real.c for TARGET_FLOAT_FORMAT definitions
15968 required by HONOR_SNANS. (may_trap_p): Floating point DIV, MOD,
99086d59
ZW
15969 UDIV, UMOD, GE, GT, LE, LT and COMPARE may always trap with
15970 -fsignaling_nans. EQ and NE only trap for flag_signaling_nans
52bfebf0
RS
15971 not flag_trapping_math (i.e. HONOR_SNANS but not HONOR_NANS).
15972
15973 * doc/invoke.texi: Document new -fsignaling-nans compiler option.
15974
e66f55b8
KG
159752002-07-27 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
15976
15977 * Makefile.in (gengtype-lex.c): Work around a bug in flex.
15978 * gengtype-lex.l (YY_USE_PROTOS): Undef.
15979 (YY_DECL): Define.
15980
a3926fe1
RS
159812002-07-27 Roger Sayle <roger@eyesopen.com>
15982
15983 * doc/invoke.texi: Document that both -fno-builtin-foo and
15984 -fno-builtin are supported by the g++ front-end.
15985
ef69da62
SS
159862002-07-27 Stan Shebs <shebs@apple.com>
15987
15988 * configure.in: Rename config_gtfiles to target_gtfiles.
15989 * configure: Regenerate.
15990 * doc/gty.texi: Update reference.
15991 * config.gcc (powerpc-*-darwin*): Set target_gtfiles
15992 instead of appending to it.
15993
a4b0320c
AH
159942002-07-25 Aldy Hernandez <aldyh@redhat.com>
15995
15996 * config/rs6000/rs6000.c (function_arg_advance): SPE vararg
15997 vectors are split into two registers.
15998 (function_arg): Same.
15999
c427db5d
R
16000Thu Jul 26 23:00:13 2002 J"orn Rennecke <joern.rennecke@superh.com>
16001
16002 * pa.md (extv): Check predicates before emitting extv_32.
16003
57ac7be9
AM
160042002-07-27 Alan Modra <amodra@bigpond.net.au>
16005
16006 * config/rs6000/rs6000.c (rs6000_traceback_name): New var.
16007 (rs6000_traceback): New var.
16008 (rs6000_override_options): Set rs6000_traceback.
16009 (rs6000_output_function_epilogue): Implement traceback options.
16010 * config/rs6000/rs6000.h (TARGET_OPTIONS): Add "traceback=".
16011 (rs6000_traceback_name): Declare.
16012
16013 * config/rs6000/rs6000.c (output_profile_hook): Don't generate profile
16014 label reference when NO_PROFILE_COUNTERS.
16015
8e51619a
JM
160162002-07-26 Jason Merrill <jason@redhat.com>
16017
16018 * function.c (assign_parms): Handle frontend-directed pass by
16019 invisible reference.
16020
b41f25cf
NB
160212002-07-26 Neil Booth <neil@daikokuya.co.uk>
16022
16023 * doc/cppopts.texi: Update.
16024
c2734e05
NB
160252002-07-26 Neil Booth <neil@daikokuya.co.uk>
16026
16027 * cppmacro.c (_cpp_create_definition): Don't attempt redefinition
16028 warnings on assertions.
16029
c372b0fa
NB
160302002-07-26 Neil Booth <neil@daikokuya.co.uk>
16031
16032 * c-common.h (RID_AND, RID_AND_EQ, RID_NOT, RID_NOT_EQ,
16033 RID_OR, RID_OR_EQ, RID_XOR, RID_XOR_EQ, RID_BITAND, RID_BITOR,
16034 RID_COMPL): Remove.
16035 * c-parse.in (rid_to_yy): Similarly.
16036
558ee214
JM
160372002-07-26 Jason Merrill <jason@redhat.com>
16038
16039 * c-dump.c: Resurrect.
16040 * tree-dump.c: Move C-specific stuff to c-dump.c.
16041 * c-common.h: Declare c_dump_tree.
16042 * c-lang.c (LANG_HOOKS_TREE_DUMP_DUMP_TREE_FN): Define.
16043 * Makefile.in (C_AND_OBJC_OBJS): Add c-dump.o.
16044 (c-dump.o): New rule.
16045
ce71f754
AM
160462002-07-26 Alan Modra <amodra@bigpond.net.au>
16047
16048 * config/rs6000/rs6000.md: Enable patterns using rlwinm for
16049 PowerPC64. Replace "T" and "S" constraints with "n" when the
16050 predicate will do. Formatting fixes.
16051 (extzvsi_internal2): Use "andi.", "andis." and attr type of "compare"
16052 as for extzvsi_internal1.
16053
e179e7d7
NB
160542002-07-25 Neil Booth <neil@daikokuya.co.uk>
16055
16056 * dwarfout.c (VERSION_ASM_OP, DERIV_BEGIN_LABEL_FMT,
16057 DERIV_END_LABEL_FMT): Remove.
16058 (SL_BEGIN_LABEL_FMT, SL_END_LABEL_FMT): Move.
16059
a2056183
NB
160602002-07-25 Neil Booth <neil@daikokuya.co.uk>
16061
16062 * objc/objc-act.c (UTAG_STATICS, UTAG_PROTOCOL_LIST, USERTYPE):
16063 Remove.
16064
308c142a
SS
160652002-07-25 Stan Shebs <shebs@apple.com>
16066
16067 * config/rs6000/rs6000.c (rs6000_emit_prologue): Remove unused
16068 local var dwarfp.
16069 (output_compiler_stub): Remove unused locals.
16070 (output_call): Always initialize line number.
16071
59324685
R
16072Thu Jul 25 20:34:50 2002 J"orn Rennecke <joern.rennecke@superh.com>
16073
16074 * sh.h (LOAD_EXTEND_OP): QImode zero-extends on SHmedia.
16075 * sh.md (truncdiqi2, movqi_media): Likewise.
16076
77bbd421
NB
160772002-07-25 Neil Booth <neil@daikokuya.co.uk>
16078
16079 * gcse.c (obstack_chunk_alloc): Remove.
16080 (gcse_alloc): Fix to count allocated bytes.
16081 * collect2.c (SYMBOL__MAIN): Remove.
16082
7bad45b0
NB
160832002-07-25 Neil Booth <neil@daikokuya.co.uk>
16084
16085 * gcc.c (TARGET_EXECUTABLE_SUFFIX): Only used if
16086 HAVE_TARGET_EXECUTABLE_SUFFIX.
16087
184166b5
R
16088Thu Jul 25 18:57:50 2002 J"orn Rennecke <joern.rennecke@superh.com>
16089
16090 * rtl.h (mem_attrs): Spell out more clearly the roles of ALIGN,
16091 SIZE, EXPR and OFFSET.
16092
40cb04f1
RH
160932002-07-25 Richard Henderson <rth@redhat.com>
16094
16095 * emit-rtl.c (set_mem_attributes): Fix size and alignment thinkos
16096 in ARRAY_REF of DECL_P case.
16097
a27fb29b
RS
160982002-07-25 Richard Sandiford <rsandifo@redhat.com>
16099
16100 * doc/invoke.texi: Document -mabi=meabi, and expand on the EABI
16101 description. Document -mips32, -mips64, and the associated -march
16102 values. Describe the "mipsN" arguments to -march. Say that the
16103 -mipsN options are equivalent to -march. Reword the description
16104 of default type sizes.
16105 * toplev.h (target_flags_explicit): Declare.
16106 * toplev.c (target_flags_explicit): New var.
16107 (set_target_switch): Update target_flags_explicit.
16108 * config/mips/abi64.h (SUBTARGET_TARGET_OPTIONS): Undefine.
16109 * config/mips/elf64.h (MIPS_ISA_DEFAULT): Undefine.
16110 * config/mips/iris6.h (SUBTARGET_ASM_SPEC): -mabi=64 implies -mips3.
16111 * config/mips/isa3264.h (MIPS_ENABLE_EMBEDDED_O32): Undefine.
16112 * config/mips/mips.h (mips_cpu_info): New struct.
16113 (mips_cpu_string, mips_explicit_type_size_string): Remove.
16114 (mips_cpu_info_table, mips_arch_info, mips_tune_info): Declare.
16115 (MIPS_CPP_SET_PROCESSOR): New macro.
16116 (TARGET_CPP_BUILTINS): Declare a macro for each supported processor.
16117 Define _MIPS_ARCH and _MIPS_TUNE.
16118 (MIPS_ISA_DEFAULT): Don't provide a default value. Instead...
16119 (MIPS_CPU_STRING_DEFAULT): Set to "from-abi" if neither it nor
16120 MIPS_ISA_DEFAULT were already defined.
16121 (MULTILIB_DEFAULTS): Add MULTILIB_ABI_DEFAULT.
16122 (TARGET_OPTIONS): Remove -mcpu and -mexplicit-type-size.
16123 (ABI_NEEDS_32BIT_REGS, ABI_NEEDS_64BIT_REGS): New.
16124 (GAS_ASM_SPEC): Remove -march, -mcpu, -mgp* and -mabi rules.
16125 (ABI_GAS_ASM_SPEC): Remove.
16126 (MULTILIB_ABI_DEFAULT, ASM_ABI_DEFAULT_SPEC): New macros.
16127 (ASM_SPEC): Add -mgp32, -mgp64, -march, -mabi=eabi and -mabi=o64.
16128 Invoke %(asm_abi_default_spec) if no ABI was specified.
16129 (CC1_SPEC): Remove ISA -> register-size rules.
16130 (EXTRA_SPECS): Remove abi_gas_asm_spec. Add asm_abi_default_spec.
16131 * config/mips/mips.c (mips_arch_info, mips_tune_info): New vars.
16132 (mips_cpu_string, mips_explicit_type_size_string): Remove.
16133 (mips_cpu_info_table): New array.
16134 (mips_set_architecture, mips_set_tune): New fns.
16135 (override_options): Rework to make -mipsN equivalent to -march.
16136 Detect more erroneous cases, including those removed from CC1_SPEC.
16137 Don't change the ABI based on architecture, or vice versa.
16138 Unify logic with GAS.
16139 (mips_asm_file_start): Get architecture name from mips_arch_info.
16140 (mips_strict_matching_cpu_name_p, mips_matching_cpu_name_p): New fns.
16141 (mips_parse_cpu): Take the name of the option as argument. Handle
16142 'from-abi'. Raise an error if the option is wrong.
16143 (mips_cpu_info_from_isa): New fn.
16144
6bbdc759
RS
161452002-07-25 Richard Sandiford <rsandifo@redhat.com>
16146
16147 * config/mips/mips.md (tablejump_mips161): Use gen_rtx_LABEL_REF.
16148 (tablejump_mips162): Likewise.
16149
80a62484
R
16150Thu Jul 25 10:23:41 2002 J"orn Rennecke <joern.rennecke@superh.com>
16151
16152 * simpify-rtx.c (simplify_subreg): Don't pass MODE_CC mode to
16153 int_mode_for_mode.
16154
ea793912
GDR
161552002-07-25 Gabriel Dos Reis <gdr@nerim.net>
16156
16157 * c-common.c (c_sizeof_or_alignof_type): Take a third argument for
99086d59 16158 complaining.
ea793912
GDR
16159 * c-common.h (c_sizeof): Adjust definition.
16160 (c_alignof): Likewise.
16161 * c-tree.h (c_sizeof_nowarn): Now macro.
16162 * c-typeck.c (c_sizeof_nowarn): Remove definition.
16163
2d615444
NB
161642002-07-25 Neil Booth <neil@daikokuya.co.uk>
16165
16166 * c-decl.c (c_decode_option): No need to handle switches
16167 cpplib handles.
16168
2be2ac70
ZW
161692002-07-24 Zack Weinberg <zack@codesourcery.com>
16170
16171 * defaults.h (ASM_OUTPUT_TYPE_DIRECTIVE, ASM_OUTPUT_SIZE_DIRECTIVE,
16172 ASM_OUTPUT_MEASURED_SIZE): New default definitions of new macros.
16173 * doc/tm.texi: Document them. Also document SIZE_ASM_OP,
16174 TYPE_ASM_OP, and TYPE_OPERAND_FMT.
16175
16176 * config/elfos.h, config/netbsd-aout.h, config/openbsd.h,
16177 config/alpha/elf.h, config/arm/elf.h, config/avr/avr.h,
16178 config/cris/aout.h, config/i386/freebsd-aout.h,
16179 config/i386/sco5.h, config/ia64/ia64.c, config/ip2k/ip2k.h,
16180 config/m68k/m68kelf.h, config/m68k/m68kv4.h, config/m88k/m88k.h,
16181 config/mcore/mcore-elf.h, config/mips/elf.h, config/mips/elf64.h,
16182 config/mips/iris6.h, config/mips/linux.h, config/pa/pa-linux.h,
16183 config/pa/pa64-hpux.h, config/rs6000/sysv4.h,
16184 config/xtensa/elf.h, config/xtensa/linux.h:
16185 Use the new macros.
16186 Where possible, remove redundant definitions of SIZE_ASM_OP,
16187 TYPE_ASM_OP, and TYPE_OPERAND_FMT.
16188
518878e1
AH
161892002-07-24 Aldy Hernandez <aldyh@redhat.com>
16190
16191 * config/rs6000/eabi.h: Define TARGET_SPE_ABI, TARGET_SPE,
16192 TARGET_ISEL, and TARGET_FPRS.
99086d59 16193
518878e1
AH
16194 * doc/invoke.texi (RS/6000 and PowerPC Options): Document
16195 -mabi=spe, -mabi=no-spe, and -misel=.
16196
16197 * config/rs6000/rs6000-protos.h: Add output_isel.
16198 Move vrsave_operation prototype here.
16199
16200 * config/rs6000/rs6000.md (sminsi3): Allow pattern for TARGET_ISEL.
16201 (smaxsi3): Same.
16202 (uminsi3): Same.
16203 (umaxsi3): Same.
16204 (abssi2_nopower): Disallow when TARGET_ISEL.
16205 (*ne0): Same.
16206 (negsf2): Change to expand and rename old pattern to *negsf2.
16207 (abssf2): Change to expand and rename old pattern to *abssf2.
99086d59 16208
518878e1
AH
16209 New expanders: fix_truncsfsi2, floatunssisf2, floatsisf2,
16210 fixunssfsi2.
16211
16212 Change patterns that check for TARGET_HARD_FLOAT or
16213 TARGET_SOFT_FLOAT to also check TARGET_FPRS.
16214
16215 * config/rs6000/rs6000.c: New globals: rs6000_spe_abi,
16216 rs6000_isel, rs6000_fprs, rs6000_isel_string.
16217 (rs6000_override_options): Add 8540 case to
16218 processor_target_table.
16219 Set rs6000_isel for the 8540.
16220 Call rs6000_parse_isel_option.
16221 (enable_mask_for_builtins): New.
16222 (rs6000_parse_isel_option): New.
16223 (rs6000_parse_abi_options): Add spe and no-spe.
16224 (easy_fp_constant): Treat !TARGET_FPRS as soft-float.
16225 (rs6000_legitimize_address): Check for TARGET_FPRS when checking
16226 for TARGET_HARD_FLOAT.
16227 Add case for SPE_VECTOR_MODE.
16228 (rs6000_legitimize_reload_address): Handle SPE vector modes.
16229 (rs6000_legitimate_address): Disallow PRE_INC/PRE_DEC for SPE
16230 vector modes.
16231 Check for TARGET_FPRS when checking for TARGET_HARD_FLOAT.
16232 (rs6000_emit_move): Check for TARGET_FPRS.
16233 Add cases for SPE vector modes.
16234 (function_arg_boundary): Return 64 for SPE vector modes.
16235 (function_arg_advance): Check for TARGET_FPRS and
16236 Handle SPE vectors.
16237 (function_arg): Same.
16238 (setup_incoming_varargs): Check for TARGET_FPRS.
16239 (rs6000_va_arg): Same.
16240 (struct builtin_description): Un-constify mask field. Move up in
16241 file.
16242 (bdesc_2arg): Un-constify and add SPE builtins.
16243 (bdesc_1arg): Same.
16244 (bdesc_spe_predicates): New.
16245 (bdesc_spe_evsel): New.
16246 (rs6000_expand_unop_builtin): Add SPE 5-bit literal builtins.
16247 (rs6000_expand_binop_builtin): Same.
16248 (bdesc_2arg_spe): New.
16249 (spe_expand_builtin): New.
16250 (spe_expand_predicate_builtin): New.
16251 (spe_expand_evsel_builtin): New.
16252 (rs6000_expand_builtin): Call spe_expand_builtin for SPE.
16253 (rs6000_init_builtins): Initialize SPE builtins. Call
16254 rs6000_common_init_builtins.
16255 (altivec_init_builtins): Move all non-altivec builtin code to...
16256 (rs6000_common_init_builtins): ...here. New function.
16257 (branch_positive_comparison_operator): Allow NE code for SPE.
16258 (ccr_bit): Return correct ccr bit for SPE fp.
16259 (print_operand): Emit crnor in 'D' case for SPE.
16260 New case 't'.
16261 Add SPE code for 'y' case.
16262 (rs6000_generate_compare): Generate rtl for SPE fp.
16263 (output_cbranch): Handle SPE hard floats.
16264 (rs6000_emit_cmove): Handle isel.
16265 (rs6000_emit_int_cmove): New.
16266 (output_isel): New.
16267 (rs6000_stack_info): Adjust stack frame so GPRs are saved in
16268 64-bits for SPE.
16269 (debug_stack_info): Add SPE info.
16270 (gen_frame_mem_offset): New.
16271 (rs6000_emit_prologue): Save GPRs in 64-bits for SPE abi.
16272 Change mode of frame pointer, when saving it, to Pmode.
16273 (rs6000_emit_epilogue): Restore GPRs in 64-bits for SPE abi.
16274 Misc cleanups and use gen_frame_mem_offset when appropriate.
16275
16276 * config/rs6000/rs6000.h (processor_type): Add PROCESSOR_PPC8540.
16277 (TARGET_SPE_ABI): New.
16278 (TARGET_SPE): New.
16279 (TARGET_ISEL): New.
16280 (TARGET_FPRS): New.
16281 (FIXED_SCRATCH): New.
16282 (RTX_COSTS): Add PROCESSOR_PPC8540.
16283 (ASM_CPU_SPEC): Add case for 8540.
16284 (TARGET_OPTIONS): Add isel= case.
16285 (rs6000_spe_abi): New.
16286 (rs6000_isel): New.
16287 (rs6000_fprs): New.
16288 (rs6000_isel_string): New.
16289 (UNITS_PER_SPE_WORD): New.
16290 (LOCAL_ALIGNMENT): Adjust for SPE.
16291 (HARD_REGNO_MODE_OK): Same.
16292 (DATA_ALIGNMENT): Same.
16293 (MEMBER_TYPE_FORCES_BLK): New.
16294 (FIRST_PSEUDO_REGISTER): Set to 113.
16295 (FIXED_REGISTERS): Add SPE registers.
16296 (reg_class): Same.
16297 (REG_CLASS_NAMES): Same.
16298 (REG_CLASS_CONTENTS): Same.
16299 (REGNO_REG_CLASS): Same.
16300 (REGISTER_NAMES): Same.
16301 (DEBUG_REGISTER_NAMES): Same.
16302 (ADDITIONAL_REGISTER_NAMES): Same.
16303 (CALL_USED_REGISTERS): Same.
16304 (CALL_REALLY_USED_REGISTERS): Same.
16305 (SPE_ACC_REGNO): New.
16306 (SPEFSCR_REGNO): New.
16307 (SPE_SIMD_REGNO_P): New.
16308 (HARD_REGNO_NREGS): Adjust for SPE.
16309 (VECTOR_MODE_SUPPORTED_P): Same.
16310 (REGNO_REG_CLASS): Same.
16311 (FUNCTION_VALUE): Same.
16312 (LIBCALL_VALUE): Same.
16313 (LEGITIMATE_OFFSET_ADDRESS_P): Same.
16314 (SPE_VECTOR_MODE): New.
16315 (CONDITIONAL_REGISTER_USAGE): Disable FPRs when target does FP on
16316 the GPRs. Set FIXED_SCRATCH fixed in SPE case.
16317 (rs6000_stack): Add spe_gp_size, spe_padding_size,
16318 spe_gp_save_offset.
16319 (USE_FP_FOR_ARG_P): Check for TARGET_FPRS.
16320 (LEGITIMATE_LO_SUM_ADDRESS_P): Same.
16321 (SPE_CONST_OFFSET_OK): New.
16322 (rs6000_builtins): Add SPE builtins.
16323
16324 * testsuite/gcc.dg/ppc-spe.c: New.
99086d59 16325
518878e1
AH
16326 * config/rs6000/eabispe.h: New.
16327
16328 * config/rs6000/spe.h: New.
16329
16330 * config/rs600/spe.md: New.
16331
16332 * config/rs6000/rs6000-c.c (rs6000_cpu_cpp_builtins): Define
16333 __SIMD__ for TARGET_SPE.
16334
16335 * config.gcc: Add powerpc-*-eabispe* case.
16336 Add spe.h to user headers for powerpc.
16337
8d1b7ba1
CD
163382002-07-24 Chris Demetriou <cgd@broadcom.com>
16339
16340 * config/mips/elf.h (STARTFILE_SPEC): Undo previous change.
16341 * config/mips/elf64.h (STARTFILE_SPEC): Likewise.
16342 * config/mips/isa3264.h (STARTFILE_SPEC): Likewise.
16343
8ad8135a
RH
163442002-07-24 Richard Henderson <rth@redhat.com>
16345
16346 * expr.c (expand_expr) [TRY_FINALLY_EXPR]: Use GOTO_SUBROUTINE_EXPR
16347 form when not optimizing.
16348
dc44a4d8
DM
163492002-07-24 David Mosberger <davidm@hpl.hp.com>
16350
16351 * config/ia64/ia64.c (gen_thread_pointer): Fix typo in marking
16352 thread_pointer_rtx as unchanging.
16353
c5605318
MM
163542002-07-24 Michael Matz <matz@suse.de>
16355
16356 * ra-colorize.c (INV_REG_ALLOC_ORDER): New macro.
16357 (free_reg): Use it.
16358
3ade30ea
RE
163592002-07-24 Richard Earnshaw <rearnsha@arm.com>
16360
16361 * arm.md (arm_buneq, arm_bltgt): put '\' before ';' in output
16362 pattern.
16363 (arm_buneq_reversed, arm_bltgt_reversed): Likewise.
16364 (movsicc, movsfcc, movdfcc): FAIL if UNEQ or LTGT.
16365
8a3ad737
CD
163662002-07-24 Chris Demetriou <cgd@broadcom.com>
16367
16368 * config/mips/elf.h (STARTFILE_SPEC): Never include crt0.o.
16369 * config/mips/elf64.h (STARTFILE_SPEC): Likewise.
16370 * config/mips/isa3264.h (STARTFILE_SPEC): Do not redefine.
16371
7e51e626
JH
16372Wed Jul 24 17:59:12 CEST 2002 Jan Hubicka <jh@suse.cz>
16373
16374 * toplev.c (rest_of_compilation): Dump loops before clobbering
16375 the structure.
16376
5df533b3
JH
16377Wed Jul 24 17:23:16 CEST 2002 Jan Hubicka <jh@suse.cz>
16378
16379 * rtlanal.c (keep_with_call_p): Avoid overflow in fixed_regs.
16380
79258dce
RS
163812002-07-24 Frank van der Linden <fvdl@wasabisystems.com>
16382
16383 PR optimization/7291
16384 * config/i386/i386.c (ix86_expand_clrstr): Fix bzero alignment
16385 problem on x86_64.
16386
26ff2117
GDR
163872002-07-24 Gabriel Dos Reis <gdr@nerim.net>
16388
16389 * pretty-print.h: Add macros from cp/error.c
16390
0ba1b2ff
AM
163912002-07-24 Alan Modra <amodra@bigpond.net.au>
16392
16393 * config/rs6000/rs6000-protos.h (mask_operand_wrap): Declare.
16394 (mask64_2_operand): Declare.
16395 (build_mask64_2_operands): Declare.
16396 (and64_2_operand): Declare.
16397 (extract_MB): Declare.
16398 (extract_ME): Declare.
16399 * config/rs6000/rs6000.c (mask64_operand): Allow all ones. Remove
16400 CONST_DOUBLE code.
16401 (mask_operand_wrap): New insn predicate.
16402 (mask64_2_operand): Likewise.
16403 (and64_2_operand): Likewise.
16404 (build_mask64_2_operands): New function.
16405 (extract_MB): New function.
16406 (extract_ME): New function.
16407 (print_operand <case m,M>): Use extract_MB and extract_ME.
16408 (print_operand <case S>): Allow all ones. Remove CONST_DOUBLE support.
16409 * config/rs6000/rs6000.h (EXTRA_CONSTRAINT): Add 't'.
16410 (PREDICATE_CODES): Add and64_2_operand, mask_operand_wrap and
16411 mask64_2_operand. Remove CONST_DOUBLE from mask64_operand.
16412 * config/rs6000/rs6000.md (andsi3_internal3): New
16413 (andsi3_internal3+1): Enable split for powerpc64.
16414 (andsi3_internal3+2): New split.
16415 (andsi3_internal4): Renamed old andsi3_internal3.
16416 (andsi3_internal5): New.
16417 (andsi3_internal5+1): Enable split for powerpc64.
16418 (andsi3_internal5+2): New split.
16419 (andsi3_internal6, andsi3_internal7, andsi3_internal8): New.
16420 (anddi3): Handle 't' constraint.
16421 (anddi3+1): New split.
16422 (anddi3_internal2): Handle 't' constraint.
16423 (anddi3_internal2+1): New split.
16424 (anddi3_internal3): Handle 't' constraint.
16425 (anddi3_internal3+1): New split.
16426
097657c3
AM
164272002-07-24 Alan Modra <amodra@bigpond.net.au>
16428
16429 * config/rs6000/rs6000.md: Remove scratch reg on insns using
16430 addze and similar (plus (comparison r1 r2) r3) insns. Add
16431 missing scratch reg in one case. Formatting fixes.
16432
a69cbaac
NB
164332002-07-24 Neil Booth <neil@daikokuya.co.uk>
16434
16435 * cppexp.c (parse_defined): Mark macro used.
16436 * cpphash.h (struct cpp_macro): New member "used".
16437 (_cpp_mark_macro_used, _cpp_warn_if_unused_macro): New.
16438 (struct cpp_reader): New member.
16439 * cppinit.c (cpp_finish_options): Set first_unused_line.
16440 (cpp_finish): Warn of unused macros if requested.
16441 (OPT_TABLE): New switches.
16442 (cpp_handle_option): Handle them.
16443 * cpplib.c (do_undef): Warn if macro unused.
16444 (do_ifdef, do_ifndef): Mark macro used.
16445 * cpplib.h (struct cpp_options): New member.
16446 * cppmacro.c (_cpp_warn_if_unused_macro): New.
16447 (enter_macro_context): Mark macro used.
16448 (_cpp_create_definition): Mark macro unused; warn if unused
16449 when redefined.
16450 * cpptrad.c (scan_out_logcial_line, push_replacement_text):
16451 Mark macros used.
16452 * doc/cppopts.texi: Update.
16453
c0667597
NB
164542002-07-23 Neil Booth <neil@daikokuya.co.uk>
16455
16456 * dwarf2out.c (SECTION_ASM_OP,
16457 ASM_OUTPUT_DEFINE_LABEL_DIFFERENCE_SYMBOL): Remove.
16458 * system.h (SECTION_ASM_OP): Poison.
16459 * tree.c (FILE_FUNCTION_PREFIX_LEN): Remove.
16460 * config/alpha/alpha-interix.h, config/mips/linux.h
16461 (ASM_OUTPUT_DEFINE_LABEL_DIFFERENCE_SYMBOL): Remove.
16462 * config/mmix/mmix-protos.h, config/mmix/mmix.c
16463 (mmix_asm_output_define_label_difference_symbol): Remove.
16464 * config/mmix/mmix.h
16465 (ASM_OUTPUT_DEFINE_LABEL_DIFFERENCE_SYMBOL): Remove.
b841421a 16466 * doc/tm.texi: Remove documentation.
c0667597 16467
bf7cd754
R
16468Tue Jul 23 21:49:24 2002 J"orn Rennecke <joern.rennecke@superh.com>
16469
16470 * recog.c (asm_operand_ok): Allow float CONST_VECTORs for 'F'.
16471 (constrain_operands): Likewise.
16472 * regclass.c (record_reg_classes): Likewise.
16473 * reload.c (find_reloads): Likewise.
16474 * doc/md.texi: Likewise.
451f86fd
R
16475
16476 * reload.c (find_reloads_toplev): Use simplify_gen_subreg.
16477 * simplify-rtx.c (simplify_subreg): When converting to a non-int
16478 mode, try to convert to an integer mode of matching size first.
1d5fa6b4
R
16479
16480 * simplify-rtx.x (simplify_subreg): When constructing a CONST_VECTOR
16481 from individual subregs, check that each subreg has been generated
16482 sucessfully.
16483
10d6af32
NB
164842002-07-23 Neil Booth <neil@daikokuya.co.uk>
16485
16486 * genautomata.c (VLA_HWINT_SHORTEN, VLA_HWINT_LAST): Remove.
16487 * df.c (HANDLE_SUBREG, FOR_EACH_BB_IN_BITMAP_REV,
16488 FOR_EACH_BB_IN_SBITMAP): Remove.
16489 * gcse.c (NEVER_SET, FOLLOW_BACK_EDGES): Remove.
16490 * haifa-sched.c (DONE_PRIORITY, MAX_PRIORITY, TAIL_PRIORITY,
16491 LAUNCH_PRIORITY, DONE_PRIORITY_P, LOW_PRIORITY_P): Remove.
16492 * loop.c (PREFETCH_BLOACK_IN_LOOP_MIN,
16493 PREFETCH_LIMIT_TO_SIMULTANEOUS): Remove.
16494 * regrename.c (REGNO_MODE_OK_FOR_BASE_P): Remove.
16495
6aaae39a
GDR
164962002-07-23 Gabriel Dos Reis <gdr@nerim.net>
16497
16498 * pretty-print.h: New file.
16499
45e574d0
JDA
165002002-07-23 Paul Koning <pkoning@equallogic.com>
16501
16502 * real.c (REAL_WORDS_BIG_ENDIAN): Make 1 for DEC.
16503 (LARGEST_EXPONENT_IS_NORMAL): Ditto.
16504 (VAX_HALFWORD_ORDER): Define (1 for DEC VAX, 0 otherwise).
16505 (TARGET_G_FLOAT): Default to 0 if not defined.
99086d59 16506 (ieeetoe): New, common routine to convert target format floats
45e574d0
JDA
16507 to internal form.
16508 (e24toe, e53toe): Change to use ieeetoe, distinguish DEC
16509 vs. others.
16510 (e113toe): Change to use ieeetoe.
16511
165122002-07-23 Roman Lechtchinsky <rl@cs.tu-berlin.de>
16513
16514 * real.c (REAL_WORDS_BIG_ENDIAN): Make sure it is 0 for DEC and 1 for
16515 IBM.
16516 (e53toe): Assume IEEE if non of DEC, IBM and C4X is defined.
16517 (e64toe): Remove special cases for DEC and IBM. Remove support for
16518 ARM_EXTENDED_IEEE_FORMAT.
16519 (e24toe): Remove special cases for DEC.
16520 (significand_size): Simplify. Indent.
16521 (ieee_format, ieee_24, ieee_53, ieee_64, ieee_113): New.
16522 (etoieee, toieee): New.
16523 (etoe113, toe113, etoe64, toe64, etoe53, toe53, etoe24, toe24): Use
16524 etoieee and toieee for IEEE arithmetic.
16525
3764f879
GDR
165262002-07-23 Gabriel Dos Reis <gdr@nerim.net>
16527
16528 * doc/extend.texi: Say ISO C90, not ISO C89.
16529 * doc/invoke.texi: Likewise.
16530 * doc/standards.texi: Likewise.
16531
aa0f70e6
SE
165322002-07-23 Steve Ellcey <sje@cup.hp.com>
16533
16534 * gcc/explow.c (convert_memory_address): Fix conversion of CONSTs.
16535 Fix permutation of conversion and plus/mult.
16536 * gcc/builtins.c (expand_builtin_memcpy) Ensure return pointer is
16537 ptr_mode and not Pmode when POINTERS_EXTEND_UNSIGNED is defined.
16538 (expand_builtin_strncpy) Ditto.
16539 (expand_builtin_memset) Ditto.
16540
fa72b064
GDR
165412002-07-23 Gabriel Dos Reis <gdr@nerim.net>
16542
16543 Fix PR/7363:
16544 * c-common.c (c_sizeof_or_alignof_type): New function.
16545 (c_alignof): Remove definition.
16546 * c-common.h (c_sizeof, c_alignof): Define as macros.
16547 (c_sizeof_or_alignof_type): Declare.
16548 (my_friendly_assert): Moved from cp/cp-tree.h
16549 * c-typeck.c (c_sizeof): Remove definition.
16550
2b773ee2
JH
165512002-07-23 Jan Hubicka <jh@suse.cz>
16552
16553 * gcse.c (try_replace_reg): Use num_changes_pending.
16554 * recog.c (num_changes_pending): New function.
16555 (validate_replace_src): Use validate_repalce_src_group.
16556 (validate_replace_src_group): New.
16557 * recog.h (validate_repalce_src_group): New.
16558 (num_changes_pending): Likewise.
16559
a0dc500c
R
16560Tue Jul 23 12:16:58 2002 J"orn Rennecke <joern.rennecke@superh.com>
16561
16562 * calls.c (emit_library_call_value_1): If
16563 FUNCTION_ARG_PASS_BY_REFERENCE is true, pretend this is neither
16564 libcall, const call nor pure call.
16565
d22eda7b
NB
165662002-07-23 Neil Booth <neil@daikokuya.co.uk>
16567
16568 * config/m88k/m88k.h (SECTION_ASM_OP): Remove.
16569
b5e66e65
NB
165702002-07-23 Neil Booth <neil@daikokuya.co.uk>
16571
16572 * vmsdbgout.c (SECTION_ASM_OP): Remove.
16573
c3a600c0
NB
165742002-07-23 Neil Booth <neil@daikokuya.co.uk>
16575
16576 * config/i386/i386.c (AT_BP): Remove.
16577
4fa31c2a
NB
165782002-07-23 Neil Booth <neil@daikokuya.co.uk>
16579
16580 * defaults.h (obstack_chunk_alloc, obstack_chunk_free):
16581 Default definition.
16582 * gcse.c: Don't define obstack_chunk_free.
16583 * collect2.c, conflict.c, df.c, diagnostic.c, fix-header.c,
16584 flow.c, gcc.c, genattrtab.c, genautomata.c, genflags.c, gensupport.c,
16585 integrate.c, loop.c, ra.c, read-rtl.c, regrename.c, reload1.c,
16586 reorg.c, tlink.c, tree.c, config/arm/arm.c, objc/objc-act.c:
16587 Don't define obstack macros.
16588
fd576c86
SC
165892002-07-22 Stephane Carrez <stcarrez@nerim.fr>
16590
16591 PR target/6744
16592 * config/m68hc11/m68hc11.c (m68hc11_z_replacement): Also replace
16593 ASM_OPERANDS instructions.
16594
b791ff31
SC
165952002-07-22 Stephane Carrez <stcarrez@nerim.fr>
16596
16597 PR target/7361
16598 * config/m68hc11/m68hc11.c (go_if_legitimate_address_internal): Accept
16599 constant addresses only on 68HC12.
16600
4a941115
NB
166012002-07-22 Neil Booth <neil@daikokuya.co.uk>
16602
16603 * cppfiles.c (stack_include_file): Correct test of whether
16604 a dependency should be output.
16605
7488cc6d
DE
166062002-07-22 David Edelsohn <edelsohn@gnu.org>
16607
16608 * collect2.c (is_ctor_dtor): Add other possible JOINER values.
16609
b41caf7c
RE
166102002-07-22 Richard Earnshaw <rearnsha@arm.com>
16611
16612 * arm.md (movqi): If optimizing and we can create pseudos, use
16613 a ZERO_EXTEND to load from memory, then copy the result into the
16614 target.
16615 (movhi): Likewise, but only for ARMv4.
16616
492e9934
NB
166172002-07-22 Neil Booth <neil@daikokuya.co.uk>
16618
16619 * ssa-ccp.c (PHI_PARMS): Remove.
16620
f01f01a6
RS
166212002-07-22 Richard Sandiford <rsandifo@redhat.com>
16622
16623 * config/mips/mips.h (CLASS_CANNOT_CHANGE_MODE): Include FP_REGS
16624 on big-endian targets.
16625
c2ae8aef
KG
166262002-07-22 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
16627
16628 * hwint.h (HOST_WIDE_INT_PRINT_DEC_SPACE,
16629 HOST_WIDE_INT_PRINT_UNSIGNED_SPACE,
16630 HOST_WIDEST_INT_PRINT_DEC_SPACE, HOST_WIDEST_INT_PRINT_DEC_SPACE):
16631 New formatting macros.
16632
16633 * ra-debug.c (dump_static_insn_cost): Avoid string concatenation.
16634
eab2120d
R
16635Mon Jul 22 15:27:25 2002 J"orn Rennecke <joern.rennecke@superh.com>
16636
16637 * rtlanal.c (subreg_regno_offset): Return correct offset for
16638 big endian paradoxical subregs.
0d541696
R
16639
16640 * optabs.c (expand_vector_unop): Don't expand using sub_optab
16641 if we got the wrong mode.
bb9b3805
R
16642
16643 * hwint.c (define HOST_WIDE_INT_PRINT_DEC_C): New define.
16644 * genrecog.c (write_switch, write_cond): Use it.
16645 * genemit.c (gen_exp): Likewise.
16646
e96eb215
JJ
166472002-07-22 Jakub Jelinek <jakub@redhat.com>
16648
16649 * c-decl.c (build_compound_literal): Set decl TREE_READONLY from TYPE.
16650
cf3c4f56
JJ
166512002-07-22 Jakub Jelinek <jakub@redhat.com>
16652
16653 * c-decl.c (build_compound_literal): Defer compound literal decls
16654 until until file end to emit them only if they are actually used.
16655
533c4863
KG
166562002-07-21 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
16657
16658 * ra-build.c (check_conflict_numbers): Hide unused function.
16659 (livethrough_conflicts_bb): Avoid automatic aggregate
16660 initialization.
16661 (parts_to_webs_1): Avoid `U' integer constant modifier.
16662 (conflicts_between_webs): Wrap a variable in the macro controlling
16663 its usage.
16664 * ra-debug.c (ra_debug_msg): Use VA_OPEN/VA_CLOSE.
16665 (dump_igraph, dump_graph_cost): Avoid string concatenation
16666 (dump_static_insn_cost): Avoid automatic aggregate
16667 initialization.
16668 * ra-rewrite.c (insert_stores): Avoid automatic aggregate
16669 initialization.
16670 (dump_cost): Avoid string concatenation
16671
8943a0b4
RH
166722002-07-21 Richard Henderson <rth@redhat.com>
16673
16674 * expr.c (expand_expr) [TRY_FINALLY_EXPR]: Don't use
16675 GOTO_SUBROUTINE_EXPR when finally_block can be re-expanded.
16676
b1aef35b
RH
166772002-07-21 Richard Henderson <rth@redhat.com>
16678
16679 * unroll.c (find_splittable_givs): Do not split DEST_ADDR givs
16680 that are not unrolled completely.
16681
5e1afb11
RH
166822002-07-21 Richard Henderson <rth@redhat.com>
16683
16684 * loop.h (LOOP_AUTO_UNROLL): Rename from LOOP_FIRST_PASS.
16685 * loop.c (strength_reduce): Update.
16686 * toplev.c (rest_of_compilation): Do unrolling in the first
16687 loop pass, not the second.
16688
c67a1cf6
RH
166892002-07-21 Richard Henderson <rth@redhat.com>
16690
16691 * emit-rtl.c (set_mem_attributes): Preserve indirection of PARM_DECL
16692 when flag_argument_noalias == 2.
16693 * alias.c (nonoverlapping_memrefs_p): Handle that.
16694 * print-rtl.c (print_mem_expr): Likewise.
16695
b68daef4
HS
166962002-07-21 Hartmut Schirmer <hartmut.schirmer@arcor.de>
16697
16698 * libgcc2.c (__divdi3, __moddi3): Use unary minus operator
16699 instead of __negdi2 directly.
16700
060a58c5
NB
167012002-07-21 Neil Booth <neil@daikokuya.co.uk>
16702
16703 * gengenrtl.c (gencode): Don't define obstack_alloc_rtx.
16704 * function.c (SYMBOL__MAIN): Remove definition.
16705 * global.c (SET_CONFLICT, REGBITP, ALLOCNO_LIVE_P): Remove.
99086d59 16706 * predict.c (PROB_NEVER, PROB_LIKELY, PROB_UNLIKELY): Remove.
060a58c5
NB
16707 * profile.c (GCOV_INDEX_TO_BB): Remove.
16708 * sched-rgn.c (ABS_VALUE, MIN_DIFF_PRIORITY, MIN_PROB_DIFF): Remove.
16709 * simplify-rtx.c (FIXED_BASE_PLUS_P): Remove.
16710
2f8dd115
NB
167112002-07-21 Neil Booth <neil@daikokuya.co.uk>
16712
16713 * c-lex.c (GET_ENVIRONMENT): Remove.
16714 * collect2.c (GET_ENV_PATH_LIST): Remove.
16715 (prefix_from_env): Use GET_ENVIRONMENT.
16716 * cppinit.c (GET_ENV_PATH_LIST): Remove.
16717 (init_standard_includes): Use GET_ENVIRONMENT.
16718 * defaults.h (GET_ENVIRONMENT): Define here if not already.
16719 * gcc.c (GET_ENV_PATH_LIST): Remove.
16720 (make_relative_prefix, process_command): Update.
16721 * protoize.c (GET_ENV_PATH_LIST): Remove.
16722 (do_processing): Update.
16723
56508306
GDR
167242002-07-21 Gabriel Dos Reis <gdr@nerim.net>
16725
16726 * c-decl.c (build_array_declarator): Say 'ISO C90', not 'ISO C89'.
16727 (grokdeclarator): Likewise.
16728 * c-format.c (C_STD_NAME): Likewise.
16729 * c-lex.c (interpret_integer): Likewise.
16730 * c-typeck.c (build_array_ref): Likewise.
16731 * cpplex.c (_cpp_lex_direct): Likewise.
16732 * toplev.c (documented_lang_options): Likewise.
16733
e2f62855
NB
167342002-07-21 Neil Booth <neil@daikokuya.co.uk>
16735
16736 * c-format.c (T99_I, T99_UI): Remove.
16737
c89d1dfd
NB
167382002-07-21 Neil Booth <neil@daikokuya.co.uk>
16739
16740 * c-typeck.c (SAVE_SPELLING_DEPTH): Remove.
16741
46690369
JH
16742Sun Jul 21 21:36:41 CEST 2002 Jan Hubicka <jh@suse.cz>
16743
16744 * gcse.c (do_local_cprop): Do not extend lifetimes of registers set by
16745 do_local_cprop.
16746
60ffc1b8
AJ
167472002-07-21 Andreas Jaeger <aj@suse.de>
16748
99086d59 16749 * reload1.c (fixup_abnormal_edges): Remove unused variable.
60ffc1b8 16750
c05ffc49
BS
167512002-07-21 Bernd Schmidt <bernds@redhat.com>
16752
16753 Improvements for the ifcvt pass from Michael Meissner, with patches
16754 by Richard Sandiford <rsandifo@redhat.com>
16755 * basic-block.h (struct ce_if_block, ce_if_block_t): New types.
16756 * ifcvt.c (cond_exec_changed_p): New static variable.
16757 (last_active_insn): New function, renamed from last_active_insn_p
16758 and changed to return the last active insn in a basic block. All
16759 callers updated.
16760 (block_fallthru): New function.
16761 (cond_exec_process_insns): New argument CE_INFO. Pass it to
16762 IFCVT_MODIFY_INSN. All callers updated.
16763 Return false if START or END are NULL.
16764 Handle case where we're processing an insn that is already
16765 conditional.
16766
16767 (noce_process_if_block): CE_INFO argument rather than
16768 multiple args containing the involved basic blocks. All callers
16769 changed.
16770 (process_if_block, merge_if_block, find_if_block,
16771 cond_exec_process_if_block): Likewise.
16772
16773 (cond_exec_process_if_block): New arg DO_MULTIPLE_P. All callers
16774 changed.
16775 Use new function last_active_insn to simplify some code.
16776 New code to handle multiple tests.
16777 Call IFCVT_MODIFY_CANCEL in all failure cases, otherwise set
16778 cond_exec_changed_p to TRUE.
16779
16780 (process_if_block): New code to handle multiple tests.
16781 (merge_if_block): Likewise.
16782 (find_if_header): New arg PASS. Changed to return the currently
16783 processed basic block or NULL instead of true/false. All callers
16784 changed.
16785 Call IFCVT_INIT_EXTRA_FIELDS.
16786 (block_jumps_and_fallthru_p): New function.
16787 (find_if_block): Discover opportunities to convert multiple tests.
16788 Add additional debugging output.
16789 Update the ce_info structure before returning.
16790
16791 (if_convert): Run multiple passes of if-conversion.
16792 * doc/tm.texi (IFCVT_MODIFY_TESTS, IFCVT_MODIFY_INSN,
16793 IFCVT_MODIFY_FINAL, IFCVT_MODIFY_CANCEL, IFCVT_MODIFY_MULTIPLE_TESTS,
16794 IFCVT_INIT_EXTRA_FIELDS, IFCVT_EXTRA_FIELDS): Update documentation for
16795 these macros.
16796
ae860ff7
JH
16797Sun Jul 21 00:54:54 CEST 2002 Jan Hubicka <jh@suse.cz>
16798
16799 * gcse.c: Include cselib.h
16800 (constptop_register): Break out from ...
16801 (cprop_insn): ... here; kill basic_block argument.
16802 (do_local_cprop, local_cprop_pass): New functions.
16803 (one_cprop_pass): Call local_cprop_pass.
16804
0da65b89
RS
168052002-07-20 Roger Sayle <roger@eyesopen.com>
16806
16807 * simplify-rtx.c (simplify_relational_operation): Optimize
16808 abs(x) < 0.0 (and abs(x) >= 0.0 when using -ffast-math).
16809
47cc673a
MM
168102002-07-20 Michae Matz <matz@suse.de>
16811
16812 * ra-build.c: (remember_web_was_spilled): Use GENERAL_REGS.
16813
68e65275
NB
168142002-07-20 Neil Booth <neil@daikokuya.co.uk>
16815
16816 * cppexp.c (struct op): Add token pointer.
16817 (check_promotion, CHECK_PROMOTION): New.
16818 (optab): Update.
16819 (_cpp_parse_expr): Update, use token pointer of struct op.
16820 (reduce): Warn about change of sign owing to promotion.
16821 * cppinit.c (cpp_handle_option): New warning if -Wall.
16822 * cpplib.h (struct cpp_options): New member.
16823
e3485bbc
DE
168242002-07-19 David Edelsohn <edelsohn@gnu.org>
16825
16826 * config/rs6000/rs6000.md: Remove ppc630 fpcompare from single
16827 fpu list. Separate Power4 compare and delayed_compare. Correct
16828 Power4 fpcompare.
16829 (fix_truncdfsi2_internal): Restore FPR preference.
16830 * config/rs6000/t-aix43 (MULTILIB_MATCHES): Add mcpu?power3,
16831 mcpu?power4, mcpu?604e. Remove mpower, mpower2, mpowerpc.
16832
449655a6
MV
168332002-07-19 Momchil Velikov <velco@fadata.bg>
16834
16835 * reload1.c (reload_as_needed): Duplicate oldpat.
16836
8b583747
AM
168372002-07-20 Alan Modra <amodra@bigpond.net.au>
16838
16839 PR optimization/7130
16840 * loop.h (struct loop_info): Add "preconditioned".
16841 * unroll.c (unroll_loop): Set it.
16842 * doloop.c (doloop_modify_runtime): Correct count for unrolled loops.
16843
0dc36574
ZW
168442002-07-19 Zack Weinberg <zack@codesourcery.com>
16845
16846 * rtl.def (CODE_LABEL): Remove slot 8.
16847 * rtl.h (struct rtx_def): Document new uses of jump and call fields.
16848 (LABEL_ALTERNATE_NAME): Delete.
16849 (LABEL_KIND, SET_LABEL_KIND, LABEL_ALT_ENTRY_P): New.
16850 * defaults.h: Remove default for ASM_OUTPUT_ALTERNATE_LABEL_NAME.
16851
16852 * final.c (output_alternate_entry_point): New.
16853 (final_scan_insn): Use it instead of
16854 ASM_OUTPUT_ALTERNATE_LABEL_NAME. Do not consider possibility
16855 of a case label being an alternate entry point.
16856
16857 * cfgbuild.c (make_edges, find_bb_boundaries): Use LABEL_ALT_ENTRY_P.
16858 * emit-rtl.c (gen_label_rtx): Adjust call to gen_rtx_CODE_LABEL.
16859 Do not clear LABEL_NUSES (unnecessary) or LABEL_ALTERNATE_NAME
16860 (field deleted).
16861 * print-rtl.c, ra-debug.c: Update code to output CODE_LABELs.
16862
16863 * doc/rtl.texi: Document LABEL_KIND, SET_LABEL_KIND, and
16864 LABEL_ALT_ENTRY_P; not LABEL_ALTERNATE_NAME.
16865 * doc/tm.texi: Delete documentation of
16866 ASM_OUTPUT_ALTERNATE_LABEL_NAME.
16867
59267987
RO
168682002-07-19 Rainer Orth <ro@TechFak.Uni-Bielefeld.DE>
16869
16870 * config/mips/iris5gas.h (DWARF2_DEBUGGING_INFO): Define.
16871 (PREFERRED_DEBUGGING_TYPE): Use DWARF2_DEBUG.
16872 (LINK_SPEC): Define.
16873 (STARTFILE_SPEC): Define.
16874 (ENDFILE_SPEC): Define.
16875
16876 * config/mips/iris6-o32.h (LINK_SPEC): Move ...
16877 * config/mips/iris6-o32-as.h (LINK_SPEC): ... here.
16878
16879 * config/mips/iris6-o32-gas.h: New file.
16880 * config.gcc (mips-sgi-irix6*o32): Use it.
16881
16882 * config/mips/t-iris5-gas: New file.
16883 * config.gcc (mips-sgi-irix6*o32, mips-sgi-irix5*): Use it.
16884
75aef48a
NB
168852002-07-19 Neil Booth <neil@daikokuya.co.uk>
16886
16887 * cppexp.c (ALWAYS_EVAL): Remove.
16888 (optab, reduce): Always evaluate.
16889 (num_unary_op, num_binary_op, num_div_op): Issue diagnostics
16890 only if not skipping evaluation.
16891
72a5503d
MM
168922002-07-19 Marek Michalkiewicz <marekm@amelek.gda.pl>
16893
16894 * config/avr/avr.c (debug_hard_reg_set): Remove.
16895
059ba716
CD
168962002-07-19 Chris Demetriou <cgd@broadcom.com>
16897
16898 * gcc.c (cpp_options): Include "%1" (cc1_spec).
16899
544823b6
RH
169002002-07-19 Richard Henderson <rth@redhat.com>
16901
16902 * loop.c (loop_givs_rescan): Delete the REG_EQUAL note, not the insn.
16903
c35383cb
AM
169042002-07-19 Alan Modra <amodra@bigpond.net.au>
16905
16906 * prefix.c (update_path): Don't zap single `.' path components
16907 unless followed by another `.' and fix typo last patch.
16908
ad28cff7
NB
169092002-07-18 Neil Booth <neil@daikokuya.co.uk>
16910
16911 * cppexp.c (cpp_num_mul): Remove unused parameter.
16912 (UNARY, BINARY, OTHER, binary_handler): Remove.
16913 (ALWAYS_EVAL): New.
16914 (optab): Update.
16915 (reduce): Refactor to a large switch, don't use a function
16916 pointer.
16917
139b7f86
BT
169182002-07-18 Bo Thorsen <bo@berlioz.suse.de>
16919
16920 * config/i386/linux64.h (STARTFILE_PREFIX_SPEC): Define this always.
16921
e69d1422
R
16922Thu Jul 18 19:39:18 2002 J"orn Rennecke <joern.rennecke@superh.com>
16923
16924 * sh-protos.h (sh_expand_unop_v2sf): Move inside #ifdef RTX_CODE guard.
16925 (sh_expand_binop_v2sf): Likewise.
16926 * sh.c (machine_dependent_reorg): Add move for UNSPEC_MOVA.
16927 (int_gpr_dest, trunc_hi_operand): New functions.
16928 * sh.h (PREDICATE_CODES): Add any_register_operand, int_gpr_dest and
16929 trunc_hi_operand.
16930 (SPECIAL_MODE_PREDICATES, any_register_operand): Define.
16931 * sh.md (cmpeqdi_t+1): Remove comments that genrecog warns about.
16932 (adddi3_compact+1, subdi3_compact+1, ashlsi3_n+1, ashlhi3+1): Likewise.
16933 (ashrsi2_16+1, ashrsi2_31+1, lshrsi3_n+1, ashrdi3+[12]): Likewise.
16934 (and_shl_scratch+[12], zero_extendhidi2+1): Likewise.
16935 (zero_extendhisi2_media+1, extendhidi2+1, extendqidi2+1): Likewise.
16936 (extendhisi2_media+1, extendqisi2_media+1): Likewise.
16937 (movsi_media_nofpu+[12], movhi_media+1, movdi_media_nofpu+1): Likewise.
16938 (movdi_const_16bit+[12], movdf_i4+[123], reload_outdf+[2-5]): Likewise.
16939 (movsf_ie+1): Likewise.
16940 (loaddi_trunc): Use int_gpr_dest predicate.
16941 (use_sfunc_addr, indirect_jump_scratch, sibcall_compact): Add mode(s).
16942 (mova, mova_const, GOTaddr2picreg, ptrel, casesi_worker_0): Likewise.
16943 (casesi_worker_0+[12], casesi_worker): Likewise.
16944 (shcompact_preserve_incoming_args): Likewise.
16945 (mov_nop): Use any_register_operand predicate.
16946 (mperm_w0): Use trunc_hi_operand predicate.
16947
47a4976f
JDA
169482002-07-18 John David Anglin <dave@hiauly1.hia.nrc.ca>
16949
16950 * pa-linux.h (DWARF2_UNWIND_INFO): Delete define.
16951 * pa.h (EH_RETURN_DATA_REGNO): Revise TARGET_64BIT and correct
16952 numbering.
16953
f3a4e54e
JDA
169542002-07-18 John David Anglin <dave@hiauly1.hia.nrc.ca>
16955
16956 * pa.c (output_deferred_plabels): Remove unused millicode enum mulU.
16957
30484ccf
RH
169582002-07-18 Richard Henderson <rth@redhat.com>
16959
16960 PR optimization/7147
16961 * ifcvt.c (noce_get_condition): Make certain that the condition
16962 is valid at JUMP.
16963
d042370e
R
16964Thu Jul 18 13:44:51 2002 J"orn Rennecke <joern.rennecke@superh.com>
16965
16966 * sh.c (barrier_align, push): Shut up compiler warnings.
16967 (initial_elimination_offset,sh_media_init_builtins): Likewise.
16968 (reg_no_subreg_operand): Delete.
16969
61fee9b3
BT
169702002-07-17 Bo Thorsen <bo@suse.de>
16971
16972 * config/i386/linux64.h (LINK_SPEC): Remove bogus -Y option.
16973 (STARTFILE_PREFIX_SPEC): Define for NATIVE_CROSS compilations.
16974 (STARTFILE_SPEC): Remove hardcoded library paths.
16975 (ENDFILE_SPEC): Likewise.
16976
f305679f
JH
16977Thu Jul 18 09:38:59 CEST 2002 Jan Hubicka <jh@suse.cz>
16978
16979 * gcse.c (hoist_expr_reaches_here_p): Stop once expr_bb is reached.
16980
16981 * gcse.c (try_replace_reg): Do not return false positives.
16982
99bcb625
AM
169832002-07-18 Alan Modra <amodra@bigpond.net.au>
16984
f6f23ad2
AM
16985 * prefix.c: (update_path): Strip ".." components when prior dir
16986 doesn't exist. Pass correct var to UPDATE_PATH_HOST_CANONICALIZE.
16987
99bcb625
AM
16988 * config/rs6000/sysv4.h (ASM_OUTPUT_REG_PUSH): Remove 64-bit support.
16989 (ASM_OUTPUT_REG_POP): Likewise.
16990
09eeeacb
AM
169912002-07-18 Alan Modra <amodra@bigpond.net.au>
16992
16993 * config/rs6000/rs6000.c (first_reg_to_save): Remove bogus
16994 adjustments to first_reg for profiling case.
16995 (output_function_profiler): Correct lr save slot for ABI_AIX_NODESC.
16996 Disable profiling for 64 bit code on both ABI_V4 and ABI_AIX_NODESC.
16997 Save static chain reg to sp + 12 on ABI_AIX_NODESC.
16998 * config/rs6000/sysv4.h (ASM_OUTPUT_REG_PUSH): Define.
16999 (ASM_OUTPUT_REG_POP): Define.
17000 * config/rs6000/linux64.h (ASM_OUTPUT_REG_PUSH): Undef.
17001 (ASM_OUTPUT_REG_POP): Undef.
17002
74d06cf2
NB
170032002-07-17 Neil Booth <neil@daikokuya.co.uk>
17004
17005 * cpplib.c (do_sccs): Handle #sccs on all systems.
17006 * system.h (SCCS_DIRECTIVE): Poison.
17007 * config/darwin.h, config/freebsd.h, config/netbsd.h,
17008 config/ptx4.h, config/svr3.h, config/svr4.h, config/alpha/elf.h,
17009 config/arm/linux-elf.h, config/c4x/c4x.h, config/d30v/d30v.h,
17010 config/i370/i370.h, config/i386/gas.h, config/i386/sco5.h,
17011 config/i960/i960.h, config/m68hc11/m68hc11.h, config/m68k/3b1.h,
17012 config/m68k/3b1g.h, config/m68k/crds.h, config/m68k/mot3300.h,
17013 config/m68k/pbb.h, config/m88k/m88k.h, config/mips/mips.h,
17014 config/sparc/pbd.h, config/stormy16/stormy16.h, config/vax/vaxv.h:
17015 Remove all references to SCCS_DIRECTIVE.
17016 * doc/cpp.texi, doc/tm.texi: Update.
17017
61dde664
R
17018Wed Jul 17 19:23:32 2002 J"orn Rennecke <joern.rennecke@superh.com>
17019
17020 * regrename.c (maybe_mode_change): New function.
17021 (find_oldest_value_reg, copyprop_hardreg_forward_1): Use it.
17022
97f51ac4
RB
170232002-07-17 Rodney Brown <rbrown64@csc.com.au>
17024
17025 * config/i386/i386.c (ix86_expand_int_movcc): In the general case
17026 suppress addition when either ct or cf are zero.
17027
a9b6f1e7 170282002-07-17 Eric Botcazou <ebotcazou@multimania.com>
30484ccf 17029 Glen Nakamura <glen@imodulo.com>
f1a73cfe
EB
17030
17031 PR optimization/6713
17032 * loop.c (loop_givs_rescan): Explicitly delete the insn that
17033 sets a non-replaceable giv after issuing the new one.
17034
23ff0223
NB
170352002-07-17 Neil Booth <neil@daikokuya.co.uk>
17036
17037 * cppexp.c (cpp_interpret_integer, append_digit, parse_defined,
17038 eval_token): Clarify and correct use of "bool" variables.
17039 * cpplib.h (struct cpp_options): Similarly.
17040 * cppmacro.c (parse_params, _cpp_save_parameter): Ditto.
17041 * cpptrad.c (recursive_macro): Similarly.
17042
ac09192a
R
17043Wed Jul 17 17:08:06 2002 J"orn Rennecke <joern.rennecke@superh.com>
17044
d28586ab 17045 * config/sh/lib1funcs.asm (udivsi3_i4): Implement SHcompact version in
ac09192a 17046 SHmedia code.
68cef009
R
17047
17048 * sh.md (cmpgtudi_media): Remove spurious @.
701e3726
R
17049
17050 * config/sh/lib1funcs.asm (FMOVD_WORKS): Don't define for little endian.
17051 * sh.h (OVERRIDE_OPTIONS): Don't set FMOVD_BIT for little endian.
ca903bba
R
17052
17053 * config/sh/lib1funcs.asm (init_trampoline): New entry point.
17054 * sh-protos.h (sh_initialize_trampoline): Declare.
17055 * sh.c (sh_initialize_trampoline): New function.
17056 * sh.h (TRAMPOLINE_SIZE): Only 24 for TARGET_SHMEDIA32.
17057 (TRAMPOLINE_ALIGNMENT): Need cache-line alignment for TARGET_SHMEDIA.
17058 (INITIALIZE_TRAMPOLINE): Call sh_initialize_trampoline.
17059 (TRAMPOLINE_ADJUST_ADDRESS): Not needed for SHcompact.
17060 * sh.md (initialize_trampoline, double_shori): New patterns.
17061 (initialize_trampoline_compact): Likewise.
17062 (shmedia32_initialize_trampoline_big): Remove.
17063 (shmedia32_initialize_trampoline_little): Likewise.
0ac78517
R
17064
17065 * sh-protos.h (binary_float_operator): Remove declaration.
17066 (sh_expand_unop_v2sf, sh_expand_binop_v2sf): Declare.
17067 * sh.c (print_operand, case 'N'): Check against CONST0_RTX.
17068 (unary_float_operator, sh_expand_unop_v2sf): New functions.
17069 (sh_expand_binop_v2sf): Likewise.
17070 (zero_vec_operand): Delete.
17071 (SH_BLTIN_UDI): New builtin shared signature define. Renumbered
17072 all non-shared ones.
17073 (bdesc): Change all the mextr builtins to use SH_BLTIN_UDI.
17074 Enable nsb and byterev.
17075 * sh.h (CONDITIONAL_REGISTER_USAGE): Initialize DF_HI_REGS.
17076 (HARD_REGNO_MODE_OK): Allow TImode in fp regs. Allow V2SFmode
17077 in general regs.
17078 (enum reg_class, REG_CLASS_NAMES, REG_CLASS_CONTENTS): Add DF_HI_REGS.
17079 (SECONDARY_OUTPUT_RELOAD_CLASS): Likewise. Remove clause for
17080 immediate operands.
17081 (SECONDARY_INPUT_RELOAD_CLASS): Add clause for immediate operands.
17082 Add DF_HI_REGS.
17083 (CLASS_CANNOT_CHANGE_MODE, CLASS_CANNOT_CHANGE_MODE_P): Allow
17084 lowpart fp regs - only for big endian for now.
da7d8304 17085 (LEGITIMATE_CONSTANT_P): Don't allow nonzero float vectors
0ac78517
R
17086 when FPU is in use.
17087 (EXTRA_CONTRAINT_U): Check against CONST0_RTX.
17088 (LOAD_EXTEND_OP): NIL for SImode.
17089 (REGISTER_MOVE_COST): Add DF_HI_REGS. Const for moves between
17090 general and fp registers is 4.
17091 PREDICATE_CODES: Amend binary_float_operator entry.
17092 Remove zero_vec_operand. Add unary_float_operator.
17093 * sh.md (udivsi3_i4_media): Use truncate instead of paradoxical
17094 subreg SET_DEST.
17095 (truncdisi2, truncdihi2, movv2sf): Allow memory destinations.
17096 (truncdiqi2): Do sign extension.
17097 (movsi_media, movdi_media): Allow to use r63 to an fp register.
17098 (movdf_media, movsf_media): Likewise.
17099 (movv2sf_i, movv2sf_i+1): Don't use f{ld,st}.p or SUBREGS.
17100 Collapse to one define_insn_and_split. Allow immediate sources.
17101 (addv2sf3, subv2sf3, mulv2sf3, divv2sf3): New patterns.
17102 (movv4sf_i): Allow immediate sources. Use simplify_gen_subreg.
17103 (movv4sf): Allow immediate sources.
17104 (movsf_media_nofpu+1): Don't split moves to FP registers.
17105 (unary_sf_op, binary_sf_op, mshflo_w_x, concat_v2sf): New patterns.
17106 (movv8qi_i+3): Check against CONST0_RTX.
17107 (mextr1, mextr2. mextr3. mextr4, mextr5, mextr6, mextr7): Use DImode
17108 for input and output operands. Fix argument 3 to gen_mextr_rl.
17109 (mmul23_wl, mmul01_wl, mmulsum_wq_i): s/const_vector/parallel/
17110 (msad_ubq_i, mshf4_b, mshf0_b, mshf4_l, mshf0_l, mshf4_w): Likewise.
17111 (mshf0_w, fipr, ftrv): Likewise.
17112 (mshfhi_l_di): Now insn_and_split. Can handle FP regs.
17113
e9d7b180
JD
171142002-07-17 Jeroen Dobbelaere <jeroen.dobbelaere@acunia.com>
17115
17116 * arm.h (ARM_NUM_INTS, ARM_NUM_REGS, ARM_NUM_REGS2): Renamed from
17117 NUM_INTS, NUM_REGS and ARM_NUM_REGS2 respectively. All uses changed.
17118 * arm.c: Similarly.
17119
8214bf98
RS
171202002-07-17 Richard Sandiford <rsandifo@redhat.com>
17121
17122 * config/mips/mips-protos.h (mips_sign_extend): Declare.
17123 * config/mips/mips.h (MASK_DEBUG_H, TARGET_DEBUG_H_MODE): Remove.
17124 (TARGET_SWITCHES): Remove debugh.
17125 (ISA_HAS_TRUNC_W): New macro.
17126 (CLASS_CANNOT_CHANGE_MODE): Include FP_REGS if TARGET_FLOAT64.
17127 (PREDICATE_CODES): Remove se_nonimmediate_operand.
17128 * config/mips/mips.c (movdi_operand): Allow sign-extensions of
17129 any SImode move_operand.
17130 (se_nonimmediate_operand): Remove.
17131 (mips_sign_extend): New.
17132 (mips_move_2words): Use it for sign-extended source operands.
17133 (override_options): Allow integers to be put into single FPRs.
17134 (mips_secondary_reload_class): Handle integers in float registers.
17135 * config/mips/mips.md (extendsidi2): Turn into a define_expand.
17136 (fix_truncsfsi2, fix_truncdfsi2): Likewise.
17137 (fix_truncdfsi2_insn, fix_truncdfsi2_macro): New.
17138 (fix_truncsfsi2_insn, fix_truncsfsi2_macro): New.
17139 (fix_truncdfdi2): Provide only a single alternative, in which the
17140 integer is in a float register. Depend on TARGET_FLOAT64 rather
17141 than TARGET_64BIT.
17142 (fix_truncsfdi2, floatdidf2, floatdisf2): Likewise.
17143 (floatsidf2, floatsisf2): Likewise, but no TARGET_FLOAT64 dependency.
17144 (movdi_internal2): Don't allow the source operand to be sign-extended.
17145 Add alternatives for float registers.
17146 (*movdi_internal2_extend): New. Version of movdi_internal2 that
17147 allows sign-extension.
17148 (*movdi_internal2_mips16): Name the existing mips16 movdi pattern.
17149 (movsi_internal2): Rename to movsi_internal. Add alternatives for
17150 float registers. Remove TARGET_DEBUG_H_MODE test.
17151 (movhi_internal1): Rename to movhi_internal. Don't check
17152 TARGET_DEBUG_H_MODE. Fix transposed *d and *f source constraints.
17153 (movqi_internal1): Rename to movqi_internal and remove
17154 TARGET_DEBUG_H_MODE dependency.
17155 (movsi_internal1, movhi_internal2, movqi_internal2): Remove.
17156
7ab0121e
JW
171572002-07-16 Jim Wilson <wilson@redhat.com>
17158
17159 * toplev.c (lang_dependent_init): Create function context for
17160 init_expr_once.
17161
349ccf2e
HPN
171622002-07-16 Hans-Peter Nilsson <hp@axis.com>
17163
17164 * config/cris/linux.h (CRIS_LINK_SUBTARGET_SPEC): Don't
17165 --gc-sections if -r.
17166 * config/cris/cris.h: Ditto.
17167
06ec023f
RB
171682002-07-16 Rodney Brown <rbrown64@csc.com.au>
17169
17170 * config/i386/i386.c (ix86_expand_int_movcc): In the case where
17171 the comparison directly gives a mask suppress addition when cf is
17172 zero by complementing the mask.
17173
39cef914
NN
171742002-07-16 Nathanael Nerode <neroden@gcc.gnu.org>
17175
17176 * Makefile.in: Delete references to enquire.
17177 * enquire.c: Move to contrib.
17178
92c1a778
SS
171792002-07-16 Stan Shebs <shebs@apple.com>
17180
2aa9948d
SS
17181 * config/darwin.h (ASM_OUTPUT_LABEL): Move to here from
17182 config/rs6000/darwin.h.
17183 (ASM_OUTPUT_SKIP): Ditto.
17184 (TEXT_SECTION_ASM_OP): Ditto.
17185 (DATA_SECTION_ASM_OP): Ditto.
17186 (ASM_APP_ON): Define.
17187 (ASM_APP_OFF): Define.
17188 * config/rs6000/darwin.h (ASM_OUTPUT_LABEL, ASM_OUTPUT_SKIP,
17189 TEXT_SECTION_ASM_OP, DATA_SECTION_ASM_OP): Remove.
17190
17191 * config/darwin.c (func_name_maybe_scoped): Remove unused decl.
92c1a778
SS
17192 (machopic_function_base_name): Declare result to be const.
17193 (machopic_non_lazy_ptr_name): Ditto.
17194 (machopic_stub_name): Ditto.
2aa9948d 17195 * config/darwin-protos.h: Ditto for the prototypes.
92c1a778 17196
daaab00a
JH
17197Wed Jul 17 00:22:39 CEST 2002 Jan Hubicka <jh@suse.cz>
17198
17199 * m68hc11.c (m68hc11_reorg): Do not rebuild CFG.
17200
63c574cc
JH
17201Wed Jul 17 00:20:48 CEST 2002 Jan Hubicka <jh@suse.cz>
17202
17203 * i386.md (prefetch): Fix for 64bit mode.
17204 (prefetch_sse_rex, prefetch_3dnow_rex): New patterns.
17205
2a500b9e
JH
17206Wed Jul 17 00:19:20 CEST 2002 Jan Hubicka <jh@suse.cz>
17207
17208 * i386.h (MACHINE_DEPENDENT_REORG): New macro.
17209 * i386.c (x86_machine_dependent_reorg): New function.
17210 * i386-protos.h (x86_machine_dependent_reorg): Declare.
17211
e5faf155
ZW
172122002-07-16 Zack Weinberg <zack@codesourcery.com>
17213
17214 * builtins.c (std_expand_builtin_va_start): Remove unused
17215 first argument.
17216 (expand_builtin_va_start): Call EXPAND_BUILTIN_VA_START and
17217 std_expand_builtin_va_start with just two arguments.
17218 * expr.h: Update prototypes.
17219
17220 * alpha-protos.h, alpha.h, alpha.c, arc-protos.h, arc.h,
17221 arc.c, d30v-protos.h, d30v.h, d30v.c, i386-protos.h, i386.h,
17222 i386.c, i960-protos.h, i960.h, i960.c, m88k-protos.h, m88k.h,
17223 m88k.c, mips-protos.h, mips.h, mips.c, mn10300-protos.h,
17224 mn10300.h, mn10300.c, pa-protos.h, pa.h, pa.c,
17225 rs6000-protos.h, rs6000.h, rs6000.c, s390-protos.h, s390.h,
17226 s390.c, sh-protos.h, sh.h, sh.c, sparc-protos.h, sparc.h,
17227 sparc.c, stormy16-protos.h, stormy16.h, stormy16.c,
17228 xtensa-protos.h, xtensa.h, xtensa.c: Remove unused first
17229 argument from all implementations of EXPAND_BUILTIN_VA_START
17230 and all uses of std_expand_builtin_va_start.
17231
dbf65c2f
R
17232Tue Jul 16 19:32:58 2002 J"orn Rennecke <joern.rennecke@superh.com>
17233
17234 * regrename.c (copy_value): Don't record high part copies.
17235
6acb6d3e 172362002-07-16 Steve Ellcey <sje@cup.hp.com>
99b823ca 17237
6acb6d3e
SE
17238 * gcc/config/pa/long_double.h (FIXUNS_TRUNCTFDI2_LIBCALL): New define.
17239 (fixunstfdi_libfunc): Change to use FIXUNS_TRUNCTFDI2_LIBCALL.
17240 * gcc/config/pa/quadlib.c (_U_Qfcnvfxt_quad_to_udbl): New function.
17241
5d7c2819
ID
172422002-07-16 Ian Dall <ian@sibyl.beware.dropbear.id.au>
17243
17244 * doc/invoke.texi (NS32K Options): Document -mieee-compare option
17245
17246 * config/ns32k/ns32k.md (addsi3, *frame_addr, *stack_addr): merge
17247 into addsi3 using register class "x" and "y".
17248
17249 * config/ns32k/ns32k.md (*madddf, *maddsf, *msubdf, *msubsf):
17250 "earlyclobber" constraint modifier for some alternative.
e5faf155 17251
5d7c2819
ID
17252 * config/ns32k/ns32k.md (tstdf, tstsf, cmpdf, cmpsf, blt, ble)
17253 (*ble, *blt): Flag to indicate bCOND and sCOND should check for
17254 unordered.
17255 config/ns32k/ns32k.h (CC_UNORD): define corresponding mask.
17256
17257 * config/ns32k/ns32k.h (TARGET_IEEE_COMPARE, MASK_IEEE_COMPARE)
17258 (TARGET_SWITCHES): Add -mieee-compare option.
17259 (OVERRIDE_OPTIONS): 32332 is a subset of
17260 32532. Don't use IEEE_COMPARE -funsafe-math-optimizations.
4977bab6 17261 (TARGET_SWITCHES): Fix description of bitfield option.
5d7c2819
ID
17262 * config/ns32k/netbsd.h (TARGET_DEFAULT): Add
17263 -mieee-compare option. Remove 32332 flag.
17264
5da4f548 172652002-07-16 Steve Ellcey <sje@cup.hp.com>
5d7c2819
ID
17266
17267 * explow.c (convert_memory_address): Remove special handling
5da4f548 17268 when POINTERS_EXTEND_UNSIGNED < 0.
5d7c2819 17269 * config/ia64.md (movsi_symbolic): New instruction for ILP32 mode.
5da4f548
SE
17270 (movedi_symbolic): Fix typo.
17271 (load_fptr): Remove mode restriction so it works for SI and DI.
17272 (load_fptr_internal1): Ditto.
17273 (load_gprel): Ditto.
17274 (load_symptr_internal1): Ditto.
17275 (call_pic): Ditto.
5d7c2819 17276 * config/ia64.c (call_operand): Modify mode check.
5da4f548
SE
17277 (ia64_expand_load_address): Handle DI and SI addresses and symbols.
17278 (ia64_expand_move): Ditto.
17279 (ia64_assemble_integer): Handle SImode function pointers.
17280 (ia64_expand_fetch_and_op): Handle SImode mem addresses.
17281 (ia64_expand_op_and_fetch): Ditto.
17282 (ia64_expand_compare_and_swap): Ditto.
17283 (ia64_expand_lock_test_and_set): Ditto.
17284 (ia64_expand_lock_release): Ditto.
17285
1575c31e
JD
172862002-07-16 Jeroen Dobbelaere <jeroen.dobbelaere@acunia.com>
17287
17288 * arm.c (emit_sfm): Don't set RTX_FRAME_RELATED_P on DWARF.
17289
172902002-07-16 Jeroen Dobbelaere <jeroen.dobbelaere@acunia.com>
17291 Richard Earnshaw <rearnsha@arm.com>
17292
e5faf155 17293 * arm.h (LEGITIMATE_PIC_OPERAND_P): Only test
1575c31e
JD
17294 CONSTANT_POOL_ADDRESS_P if a SYMBOL_REF. Simplify logic.
17295
3894f59e
RE
172962002-07-16 Richard Earnshaw <rearnsha@arm.com>
17297
17298 * arm.md (stack_tie): New insn. Use an idiom that the alias code
17299 understands to be a memory clobber.
17300 * arm.c (arm_expand_prologue): Use it.
17301
e0b89be2 173022002-07-16 Daniel Berlin <dberlin@dberlin.org>
54b2a7f8
DB
17303
17304 * ra-rewrite.c: #include reload.h, insn-config.h
17305 * ra-build.c: #include reload.h
17306 * Makefile.in: Update ra-rewrite.o, ra-build.o dependencies to
e5faf155 17307 depend on reload.h, insn-config.h.
54b2a7f8 17308
cffa2189
R
17309Tue Jul 16 11:57:45 2002 J"orn Rennecke <joern.rennecke@superh.com>
17310
17311 * expr.c (emit_move_insn_1): Handle arbitrary moves that are
17312 the same size as a word.
17313
17314 * regrename.c (find_oldest_value_reg): Take WORDS_BIG_ENDIAN /
17315 BYTES_BIG_ENDIAN into account.
17316
052c96b1
JH
17317Tue Jul 16 12:22:44 CEST 2002 Jan Hubicka <jh@suse.cz>
17318
17319 * i386.md (prefetch): Fix for 64bit mode.
17320 (prefetch_sse_rex, prefetch_3dnow_rex): New patterns.
17321
17322 * i386.md (movss, movsd): Use xorps/xorpd for Athlon.
17323
ae32926b
MM
173242002-07-16 Marek Michalkiewicz <marekm@amelek.gda.pl>
17325
17326 * hard-reg-set.h (TEST_HARD_REG_BIT): Return 1 if the bit is set.
17327
6c535c69
ZW
173282002-07-15 Zack Weinberg <zack@codesourcery.com>
17329
17330 * ginclude/varargs.h: Replace with stub which issues #error.
17331 * ginclude/stdarg.h: __builtin_stdarg_start is renamed
17332 __builtin_va_start.
17333
17334 * builtins.def (BUILT_IN_VARARGS_START): Delete.
17335 (BUILT_IN_VA_START): New.
17336 * builtins.c (expand_builtin_va_start): Eliminate first
17337 argument and code to implement pre-ISO varargs.
17338 (std_expand_builtin_va_start): Ignore first argument; it is
17339 always 1.
17340 (expand_builtin): Handle BUILT_IN_VA_START and
17341 BUILT_IN_STDARG_START identically. Delete
17342 BUILT_IN_VARARGS_START case.
17343
17344 * function.c (assign_parms): Delete hide_last_arg and all
17345 its uses.
17346 (mark_varargs): Delete function.
17347 * function.h (struct function): Delete 'varargs' bit.
17348 (current_function_varargs): Delete macro.
17349 * tree.h: Don't declare mark_varargs.
17350
17351 * c-decl.c (c_function_varargs, c_mark_varargs): Delete.
17352 (c_expand_body): Don't call mark_varargs.
17353 * c-objc-common.c: Handle BUILT_IN_VA_START and
17354 BUILT_IN_STDARG_START identically. Delete
17355 BUILT_IN_VARARGS_START case.
17356 * c-tree.h: Don't declare c_mark_varargs.
17357 * c-parse.in: Remove grammar rules for '&...' (which has been
17358 commented out since before 2.7.2) and for '...' in K+R
17359 argument declarations.
17360
17361 * builtins.c, function.c, integrate.c, sibcall.c,
17362 config/alpha/unicosmk.h, config/arc/arc.c, config/arc/arc.h,
17363 config/avr/avr.c, config/cris/cris.c, config/fr30/fr30.c,
17364 config/i960/i960.c, config/i960/i960.md, config/m32r/m32r.c,
17365 config/m32r/m32r.h, config/m88k/m88k.c, config/m88k/m88k.h,
17366 config/mips/mips.c, config/mmix/mmix.c, config/mmix/mmix.h,
17367 config/mn10300/mn10300.c, config/pa/som.h, config/s390/s390.c,
17368 config/sh/sh.c, config/sh/sh.h, config/sparc/sparc.h,
17369 config/stormy16/stormy16.c: Delete all references to
17370 current_function_varargs, and code predicated on that flag.
17371
17372 * config/alpha/alpha.c (alpha_va_start),
17373 config/arc/arc.c (arc_va_start),
17374 config/i386/i386.c (ix86_va_start),
17375 config/mips/mips.c (mips_va_start),
17376 config/mn10300/mn10300.c (mn10300_va_start),
17377 config/rs6000/rs6000.c (rs6000_va_start),
17378 config/s390/s390.c (s390_va_start),
17379 config/sh/sh.c (sh_va_start),
17380 Ignore first argument; it is always 1.
17381
17382 * config/c4x/c4x-protos.h, config/c4x/c4x.c: Delete c4x_va_start.
17383 * config/ia64/ia64-protos.h, config/ia64/ia64.c: Delete ia64_va_start.
17384 * config/m68hc11/m68hc11-protos.h, config/m68hc11/m68hc11.c:
17385 Delete m68hc11_va_start.
17386 * config/c4x/c4x.h, config/ia64/ia64.h, config/m68hc11/m68hc11.h:
17387 No need to define EXPAND_BUILTIN_VA_START.
17388
17389 * doc/invoke.texi, doc/sourcebuild.texi, doc/tm.texi,
17390 doc/trouble.texi: Remove references to GCC-provided <varargs.h>.
17391
6d80a854
EB
173922002-07-15 Eric Botcazou <ebotcazou@multimania.com>
17393
17394 PR optimization/7153
17395 * regmove.c (optimize_reg_copy_3): Don't optimize if the register
17396 dies in more than one insn.
17397
043cfcbe
JT
173982002-07-15 Jason Thorpe <thorpej@wasabisystems.com>
17399
17400 * config/sparc/netbsd-elf.h (TRANSFER_FROM_TRAMPOLINE): Remove.
17401
ed8d2920 174022002-07-15 Michael Matz <matz@suse.de>,
6c535c69 17403 Daniel Berlin <dberlin@dberlin.org>,
ed8d2920
MM
17404 Denis Chertykov <denisc@overta.ru>
17405
17406 Add a new register allocator.
17407
17408 * ra.c: New file.
17409 * ra.h: New file.
17410 * ra-build.c: New file.
17411 * ra-colorize.c: New file.
17412 * ra-debug.c: New file.
17413 * ra-rewrite.c: New file.
17414
17415 * Makefile.in (ra.o, ra-build.o, ra-colorize.o, ra-debug.o,
17416 (ra-rewrite.o): New .o files for libbackend.a.
17417 (GTFILES): Add basic-block.h.
17418
17419 * toplev.c (flag_new_regalloc): New.
17420 (f_options): New option "new-ra".
17421 (rest_of_compilation): Call initialize_uninitialized_subregs()
17422 only for the old allocator. If flag_new_regalloc is set, call
17423 new allocator, instead of local_alloc(), global_alloc() and
17424 friends.
17425
17426 * doc/invoke.texi: Document -fnew-ra.
17427 * basic-block.h (FOR_ALL_BB): New.
17428 * config/rs6000/rs6000.c (print_operand): Write small constants
17429 as @l+80.
17430
17431 * df.c (read_modify_subreg_p): Narrow down cases for a rmw subreg.
17432 (df_reg_table_realloc): Make size at least as large as max_reg_num().
17433 (df_insn_table_realloc): Size argument now is absolute, not relative.
17434 Changed all callers.
17435
17436 * gengtype.c (main): Add the pseudo-type "HARD_REG_SET".
17437 * regclass.c (reg_scan_mark_refs): Ignore NULL rtx's.
17438
17439 2002-06-20 Michael Matz <matz@suse.de>
17440
17441 * df.h (struct ref.id): Make unsigned.
17442 * df.c (df_bb_reg_def_chain_create): Remove unsigned cast.
17443
17444 2002-06-13 Michael Matz <matz@suse.de>
17445
17446 * df.h (DF_REF_MODE_CHANGE): New flag.
17447 * df.c (df_def_record_1, df_uses_record): Set this flag for refs
17448 involving subregs with invalid mode changes, when
17449 CLASS_CANNOT_CHANGE_MODE is defined.
17450
17451 2002-05-07 Michael Matz <matz@suse.de>
17452
17453 * reload1.c (fixup_abnormal_edges): Don't insert on NULL edge.
17454
17455 2002-05-03 Michael Matz <matz@suse.de>
17456
17457 * sbitmap.c (sbitmap_difference): Accept sbitmaps of different size.
17458
17459 Sat Feb 2 18:58:07 2002 Denis Chertykov <denisc@overta.ru>
17460
17461 * regclass.c (regclass): Work with all regs which have sets or
17462 refs.
17463 (reg_scan_mark_refs): Count regs inside (clobber ...).
17464
17465 2002-01-04 Michael Matz <matzmich@cs.tu-berlin.de>
17466
17467 * df.c (df_ref_record): Correctly calculate SUBREGs of hardregs.
17468 (df_bb_reg_def_chain_create, df_bb_reg_use_chain_create): Only
17469 add new refs.
17470 (df_bb_refs_update): Don't clear insns_modified here, ...
17471 (df_analyse): ... but here.
17472
17473 * sbitmap.c (dump_sbitmap_file): New.
17474 (debug_sbitmap): Use it.
17475
17476 * sbitmap.h (dump_sbitmap_file): Add prototype.
17477
17478 2001-08-07 Daniel Berlin <dan@cgsoftware.com>
17479
17480 * df.c (df_insn_modify): Grow the UID table if necessary, rather
17481 than assume all emits go through df_insns_modify.
17482
17483 2001-07-26 Daniel Berlin <dan@cgsoftware.com>
17484
17485 * regclass.c (reg_scan_mark_refs): When we increase REG_N_SETS,
17486 increase REG_N_REFS (like flow does), so that regclass doesn't
17487 think a reg is useless, and thus, not calculate a class, when it
17488 really should have.
17489
17490 2001-01-28 Daniel Berlin <dberlin@redhat.com>
17491
17492 * sbitmap.h (EXECUTE_IF_SET_IN_SBITMAP_REV): New macro, needed for
17493 dataflow analysis.
17494
794a292d
JJ
174952002-07-15 Jakub Jelinek <jakub@redhat.com>
17496
17497 PR middle-end/7245
17498 * config/i386/i386.c (const_int_1_31_operand): New.
17499 * config/i386/i386.h (PREDICATE_CODES): Add it.
17500 * config/i386/i386.md (ashlsi3_cmp, ashlsi3_cmp_zext, ashlhi3_cmp,
17501 ashlqi3_cmp, ashrsi3_cmp, ashrsi3_cmp_zext, ashrhi3_cmp, ashrqi3_cmp,
17502 lshrsi3_cmp, lshrsi3_cmp_zext, lshrhi3_cmp, lshrqi3_cmp): Use it.
17503
05d49501
AM
175042002-07-14 Alan Modra <amodra@bigpond.net.au>
17505
17506 PR target/7282
17507 * config/rs6000/rs6000.md (floatsidf2): Enable for POWERPC64.
17508 (floatunssidf2): Likewise.
17509 (floatsidf_ppc64): New insn_and_split.
17510 (floatunssidf_ppc64): Likewise.
17511
e89617fe
AJ
175122002-07-14 Andreas Jaeger <aj@suse.de>
17513
17514 * config.gcc (sh64): Remove unused
17515 target_requires_64bit_host_wide_int.
17516
78762e3b
RS
175172002-07-12 Roger Sayle <roger@eyesopen.com>
17518
17519 * expr.c [CLEAR_RATIO]: New macro defining the maximum number
17520 of move instructions to use when clearing memory, c.f. MOVE_RATIO.
17521 [CLEAR_BY_PIECES]: New macro, using CLEAR_RATIO, to determine
17522 whether clear_by_pieces should be used to clear storage.
17523 (clear_storage): Use CLEAR_BY_PIECES instead of MOVE_BY_PIECES.
17524
17525 * doc/tm.texi: Document these two new target macros.
17526
f7a454e9
SC
175272002-07-12 Stephane Carrez <stcarrez@nerim.fr>
17528
17529 * config/m68hc11/m68hc11.md ("zero_extendsidi2"): Use D_REG only for
17530 the scratch register.
17531 ("*movhi2_push"): Accept Z_REG because a split pattern can make use
17532 of it, forbid reload to use it.
17533
26af4041
MM
175342002-07-12 Marek Michalkiewicz <marekm@amelek.gda.pl>
17535
17536 * config/avr/avr.c (test_hard_reg_class): Fix TEST_HARD_REG_BIT
17537 usage on 64-bit hosts, return value was truncated to 32 bits.
17538
226cfe61
R
17539Fri Jul 12 00:49:36 2002 J"orn Rennecke <joern.rennecke@superh.com>
17540
17541 * simplify-rtx.c (simplify_subreg): Handle floating point
17542 CONST_DOUBLEs. When an integer subreg of a smaller mode than
17543 the element mode is requested, compute a subreg with an
17544 integer mode of the same size as the element mode first.
17545
25c25947
R
17546Thu Jul 11 22:02:57 2002 J"orn Rennecke <joern.rennecke@superh.com>
17547
17548 * combine.c (try_combine): When converting a paradoxical subreg
17549 to an extension, take LOAD_EXTEND_OP into account.
17550
789b7de5
RO
175512002-07-11 Rainer Orth <ro@TechFak.Uni-Bielefeld.DE>
17552
17553 * config.gcc (mips-sgi-irix6*o32): New configuration.
17554
17555 * configure.in (libgcc_visibility): Disable for mips-sgi-irix6*o32
17556 configurations.
17557 * configure: Regenerate.
17558
17559 * config/mips/iris6-o32-as.h: New file.
17560 * config/mips/iris6-o32.h: New file.
e89617fe 17561
789b7de5
RO
17562 * config/mips/iris5gas.h (TARGET_ASM_NAMED_SECTION): Define.
17563 (NM_FLAGS): Define.
17564 (HAVE_AS_SHF_MERGE): Undefine.
17565
17566 * config/mips/t-iris5-as: New file.
17567 * config.gcc (mips-sgi-irix6*o32, mips-sgi-irix5*): Use it.
17568
17569 * config/mips/t-iris6 (SHLIB_EXT, SHLIB_SOLINK, SHLIB_SONAME,
17570 SHLIB_NAME, SHLIB_MAP, SHLIB_OBJS, SHLIB_SLIBDIR_QUAL, SHLIB_LINK,
17571 SHLIB_INSTALL, SHLIB_MKMAP, SHLIB_MAPFILES, FPBIT, DPBIT,
17572 dp-bit.c, fp-bit.c): Move ...
17573 * config/mips/t-iris5-6: ... here.
17574 New file, shared by IRIX 5 and IRIX 6.
17575 * config.gcc (mips-sgi-irix6*o32, mips-sgi-irix6*,
17576 mips-sgi-irix5*): Use it.
17577
17578 * config/mips/iris6.h: Remove duplicate comment.
17579
17580 * config/mips/mips.c (TARGET_ASM_UNALIGNED_DI_OP) [TARGET_IRIX5 &&
17581 !TARGET_IRIX6]: Define.
17582 (mips_asm_file_start): Don't emit mdebug.<ABI> sections on IRIX 5/6.
17583
17584 * config/mips/mips.h (ASM_DECLARE_FUNCTION_NAME): Fix comment.
17585
a18c2c5f
JDA
175862002-07-11 John David Anglin <dave@hiauly1.hia.nrc.ca>
17587
17588 * pa.md (adddi3): Change predicate of operand 2 to adddi3_operand
17589 and delete code to force constant to register.
17590 * pa-protos.h (adddi3_operand): Add prototype.
17591 * pa.c (adddi3_operand): New function.
17592
e65a2d65
RS
175932002-07-11 Roger Sayle <roger@eyesopen.com>
17594
17595 * c-decl.c (duplicate_decls): Preserve the noreturn attribute on
17596 non-ANSI builtin functions.
17597
a06e3c40
R
17598Thu Jul 11 11:31:12 2002 J"orn Rennecke <joern.rennecke@superh.com>
17599
17600 * rtl.h (gen_rtx_CONST_VECTOR): Declare.
17601 * gengenrtl.c (special_rtx): Check for CONST_VECTOR.
17602 * emit-rtl.c (gen_rtx_CONST_VECTOR): New function.
17603 (gen_const_vector_0): Use it.
17604
47abc309
JDA
176052002-07-11 John David Anglin <dave@hiauly1.hia.nrc.ca>
17606
17607 * pa.md (adddi3): For 32-bit targets, force constants to a register
17608 if they don't fit in an 11-bit immediate. Change insn predicate to
17609 arith11_operand. Remove comment.
17610 * pa.c (cint_ok_for_move): Fix comment.
17611 (emit_move_sequence): Don't directly split DImode constants on 32-bit
17612 targets.
17613
8ac9d31f
TJ
176142002-07-11 Tim Josling <tej@melbpc.org.au>
17615
e89617fe 17616 Remove front end hard coding from gengtype.c.
8ac9d31f
TJ
17617
17618 * Makefile.in
17619 (STAGESTUFF): add gtyp-gen.h
17620 (GTFILES): Remove front end specific files.
17621 (GTFILES_FILES_LANGS): New, from configure..
17622 (GTFILES_FILES_FILES): Likewise.
17623 (GTFILES_LANG_DIR_NAMES): Likewise.
17624 (GTFILES_SRCDIR): Likewise.
17625 (gtyp-gen.h): Build from configure information.
17626 (s-gtype): Remove command line parameters from gengtype.
17627 (gengtype.o): Remove dependency on GTFILES. Depend on gtyp-gen.h.
17628 (mostlyclean): Delete files generated by and for gengtype.
17629
17630 * c-config-lang.in: New file.
17631
17632 * configure.in (all_gtfiles_files_langs): New. Accumulate files
17633 for each language.
17634 (all_gtfiles_files_files): New. Accumulate language for each file
17635 accumulated.
17636 (gtfiles): Pick up value for C.
17637 (srcdir): AC-SUBST this variable.
17638 (all_gtfiles_files_langs): AC-SUBST this variable.
17639 (all_gtfiles_files_files): AC-SUBST this variable.
e89617fe 17640
8ac9d31f 17641 * configure: Regenerate.
e89617fe 17642
8ac9d31f
TJ
17643 * gengtype-lex.l (parse_file): Make parameter const.
17644
17645 * gengtype.c (toplevel): include gtyp-gen.h.
17646 (BASE_FILE_<language> unnamed enum): Delete.
17647 (lang_names): Delete (replaced by gtyp-gen.h)
17648 (lang_dir_names): From gtyp-gen.h, replaces lang_names; changed
17649 all references.
17650 (NUM_GT_FILES): New.
17651 (NUM_LANG_FILES): New.
17652 (srcdir_len): New.
17653 (NUM_BASE_FILES): Change calculation.
17654 (open_base_files): Change prototype to avoid warning.
17655 (startswith): Delete.
17656 (get_file_basename): Iterate through generated language list not
17657 hard coded list.
17658 (get_base_file_bitmap): Use generated list of files and languages.
17659 (close_output_files): Add prototype to rmove warning.
17660 (main): Iterate through list of generated files from gtyp-gen.h
17661 rather than command line paramaters. Ignore duplicated file
e89617fe 17662 names.
8ac9d31f
TJ
17663
17664 * gengtype.h (parse_file): Amend prototype for const parameter.
e89617fe 17665
8ac9d31f
TJ
17666 * doc/sourcebuild.texi: Document gtfiles variable.
17667
17668 * doc/gty.texi: Document changes to gtfiles variable for front
17669 ends.
17670
17671 * objc/config-lang.in (gtfiles): Add files needed for objc front
17672 end.
17673
0e603223
RS
176742002-07-10 Roger Sayle <roger@eyesopen.com>
17675
17676 PR c/2454
17677 * combine.c (nonzero_bits): LOAD_EXTEND_OP should only apply
17678 to SUBREGs of MEMs. (num_sign_bit_copies): Likewise.
17679
c5358a5d
RS
176802002-07-10 Roger Sayle <roger@eyesopen.com>
17681 Zack Weinberg <zack@codesourcery.com>
17682
17683 * builtins.def: Make the argument types of abort and exit
17684 independent of the front-end.
17685
a35f8b74
AM
176862002-07-11 Alan Modra <amodra@bigpond.net.au>
17687
17688 * config/rs6000/linux64.h (ASM_SPEC): Define.
17689
89e7058f
AH
176902002-07-10 Aldy Hernandez <aldyh@redhat.com>
17691
6c535c69
ZW
17692 * config/rs6000/rs6000.c (emit_frame_save): New.
17693 (rs6000_frame_related): Replace reg2 before reg.
17694 (rs6000_emit_prologue): Use emit_frame_save for saving gprs, fprs,
17695 and eh_return registers.
89e7058f 17696
086bbd21
TM
176972002-07-10 Toon Moene <toon@moene.indiv.nluug.nl>
17698
17699 Revert all patches for optimization of Complex .op. Real.
17700 * complex_part_zero_p: Remove
17701 * expand_cmplxdiv_straight: Replace complex_part_zero_p(x)
17702 with x.
17703 * expand_cmplxdiv_wide: Ditto.
17704 * expand_binop: Ditto.
17705
126dbce0
MM
177062002-07-10 Marek Michalkiewicz <marekm@amelek.gda.pl>
17707
17708 * config/avr/avr.md: Fix two 0x80000000 constants to make them
17709 negative also on 64-bit hosts.
17710
17711 Default to -fno-reorder-blocks when optimizing for size.
17712 * config/avr/avr-protos.h (avr_optimization_options): Declare.
17713 * config/avr/avr.c (avr_optimization_options): New function.
17714 * config/avr/avr.h (OPTIMIZATION_OPTIONS): New.
17715
17716 Optimize returning from simple functions.
17717 * config/avr/avr-protos.h (avr_simple_epilogue): Declare.
17718 * config/avr/avr.c (avr_simple_epilogue): New function.
17719 * config/avr/avr.md (return): New insn.
17720
21c318ba
DR
177212002-07-10 Douglas B Rupp <rupp@gnat.com>
17722
17723 * config/i386/i386.c (ix86_svr3_asm_out_constructor): Add
17724 HAS_INIT_SECTION to protection.
17725
537834c8
MM
177262002-07-10 Mark Mitchell <mark@codesourcery.com>
17727
17728 * doc/invoke.texi (Debugging Options): Mention that -gdwarf is
17729 deprecated.
17730
80ba02b1
R
17731Wed Jul 10 19:50:03 2002 J"orn Rennecke <joern.rennecke@superh.com>
17732
17733 * combine.c (gen_lowpart_for_combine): Handle vector modes.
17734 Supply non-VOID mode to simplify_gen_subreg.
17735
ae3aa00d
JH
17736Wed Jul 10 18:48:55 CEST 2002 Jan Hubicka <jh@suse.cz>
17737
17738 * i386.c (ix86_init_mmx_sse_builtins): Fix thinko.
17739
029f3983
JL
177402002-07-10 Jeffrey A Law <law@redhat.com>
17741
7a464913
JL
17742 * mn10200.c (expand_prologue): Create REG_MAYBE_DEAD notes
17743 as appropriate.
17744
6c535c69
ZW
17745 * mn10200.c (expand_epilogue): Fix test to determine which scratch
17746 register to use.
029f3983 17747
ff27a429
R
17748Wed Jul 10 16:06:00 2002 J"orn Rennecke <joern.rennecke@superh.com>
17749
17750 * cse.c (cse_insn): Supply proper SUBREG_BYTE to simplify_gen_subreg.
17751 Get mode from dest.
17752 If simplify_gen_subreg fails, try next equivalent.
17753
e6986399
GDR
177542002-07-09 Gabriel Dos Reis <gdr@codesourcery.com>
17755
17756 * diagnostic.h: #include location.h
17757 (location_t): Move definition to..
17758 * location.h: ... here. New file.
17759 * tree.h: #include location.h
17760 (DECL_SOURCE_LOCATION): New macro.
17761 (DECL_SOURCE_FILE): Use.
17762 (DECL_SOURCE_LINE): Likewise.
17763 (struct tree_decl): REplace filename and linenum with locus.
17764 * Makefile.in (TREE_H): add location.h
17765 (diagnostic.o): Depends on gt-location.h
17766 (gt-location.h): Depends on s-gtype
17767
7990b46f
MK
177682002-07-09 Matt Kraai <kraai@alumni.cmu.edu>
17769
17770 * config/rs6000/aix.h: Convert CPP_PREDEFINES to
17771 TARGET_OS_CPP_BUILTINS.
17772 * config/rs6000/aix31.h: Likewise.
17773 * config/rs6000/aix41.h: Likewise.
17774 * config/rs6000/aix43.h: Likewise.
17775 * config/rs6000/aix51.h: Likewise.
17776 * config/rs6000/beos.h: Likewise.
17777 * config/rs6000/darwin.h: Likewise.
17778 * config/rs6000/eabi.h: Likewise.
17779 * config/rs6000/eabisim.h: Likewise.
17780 * config/rs6000/linux.h: Likewise.
17781 * config/rs6000/linux64.h: Likewise.
17782 * config/rs6000/lynx.h: Likewise.
17783 * config/rs6000/mach.h: Likewise.
17784 * config/rs6000/rtems.h: Likewise.
17785 * config/rs6000/sysv4.h: Likewise.
17786 * config/rs6000/vxppc.h: Likewise.
efa39e99
DP
17787
177882002-07-09 Devang Patel <dpatel@apple.com>
17789 * objc/objc-act.c (adjust_type_for_id_default): Fix my previous patch.
17790 Do not allow ObjC objects as a parameter type for Objective-C methods.
17791 My previous patch restricted 'struct' also.
e89617fe 17792
cd98faa1
NB
177932002-07-09 Neil Booth <neil@daikokuya.co.uk>
17794
17795 * cpperror.c (cpp_error): Default to directive_line within
17796 directives here.
17797 * cppexp.c (cpp_interpret_integer): Only use traditional
17798 number semantics in directives.
17799 * cpplib.c (prepare_directive_trad): Don't reset pfile->line.
17800 (do_include_common): Similarly.
17801 * cpptrad.c (scan_out_logical_line): Implement accurate
17802 quoting of <> in #include.
17803 * doc/cpp.texi: Update.
17804
2ad65b0e 17805Tue Jul 9 22:37:44 2002 Stephen Clarke <stephen.clarke@superh.com>
6c535c69 17806 J"orn Rennecke <joern.rennecke@superh.com>
2ad65b0e
SC
17807
17808 * sh.c (sh_adjust_cost): Special handling of SHMEDIA code.
17809 * sh.md (attribute issues): Replace with:
17810 (attribute pipe_model). All users changed.
17811 (attribute type): Change pt / ptabs to pt_media / ptabs_media.
17812 All users changed.
17813 (function units sh5issue, sh5fds): New.
17814 (attribute is_mac_media): New.
17815 (adddi3_media, subdi3_media, divsi3_i1_media, anddi3): Add type.
17816 (andcdi3, iordi3, xordi3, ashldi3_media, lshrdi3_media): Likewise.
17817 (ashrdi3_media, negdi_media, extendsidi2, movqi_media): Likewise.
17818 (movhi_media, shori_media, movv2sf_i, jump_media): Likewise.
17819 (call_media, call_value_media, sibcall_media): Likewise.
17820 (casesi_jump_media, casesi_shift_media, casesi_load_media): Likewise.
17821 (return_media_i, addsf3_media, subsf3_media, mulsf3_media): Likewise.
17822 (mac_media, divsf3_media, floatdisf2, floatsisf2_media): Likewise.
17823 (fix_truncsfdi2, fix_truncsfsi2_media, cmpeqsf_media): Likewise.
17824 (cmpgtsf_media, cmpgesf_media, cmpunsf_media, negsf2_media): Likewise.
17825 (sqrtsf2_media, abssf2_media, adddf3_media, subdf3_media): Likewise.
17826 (muldf3_media, divdf3_media, floatdidf2, floatsidf2_media): Likewise.
17827 (fix_truncdfdi2, fix_truncdfsi2_media, cmpeqdf_media): Likewise.
17828 (cmpgtdf_media, cmpgedf_media,cmpundf_media, negdf2_media): Likewise.
17829 (sqrtdf2_media, absdf2_media, extendsfdf2_media): Likewise.
17830 (truncdfsf2_media): Likewise.
17831 (movsi_media, movsi_media_nofpu, movdi_media): Use new types.
17832 (movdi_media_nofpui, movdf_media, movdf_media_nofpu): Likewise.
17833
b6d33983
R
17834Tue Jul 9 21:39:50 2002 J"orn Rennecke <joern.rennecke@superh.com>
17835
17836 * sh.h (PREDICATE_CODES): Add general_extend_operand and inqhi_operand.
17837 * sh.c (general_extend_operand, inqhi_operand): New functions.
17838 * sh.md (cmpeqdi_media, cmpgtdi_media, cmpgtudi_media): Collapse
17839 alternatives using 'N' modifier. Add type.
17840 (adddi3z_media): Likewise. Enable generator function generation.
17841 (movdicc_false, movdicc_true, addsi3_media, subsi3_media): Use more
17842 exact predicates / constraints. Add type.
17843 (subsi3): Allow 0 for SHMEDIA.
17844 (udivsi3_i4_media): Use match_operand for input values
17845 rather than hard registers.
17846 (udivsi3 - TARGET_SHMEDIA_FPU case): Don't ferry values
17847 unnecessarily through hard registers. Keep copies of pseudo
17848 registers outside of the libcall sequence.
17849 (mulsidi3_media, umulsidi3_media): Use more exact predicates. Add type.
17850 (ashlsi3_media, ashrsi3_media, lshrsi3_media): Likewise.
17851 (zero_extendsidi2, zero_extendhidi2, zero_extendqidi2): Likewise.
17852 (extendhidi2, extendqidi2): Likewise.
17853 (andsi3_compact): Name.
17854 (andcdi3): Enable generator function generation.
17855 (zero_extendhisi2, zero_extendqisi2): Rename to
17856 (zero_extendhisi2_compact, zero_extendqisi2_compact).
17857 (extendhisi2, extendqisi2): Rename to
17858 (extendhisi2_compact, extendqisi2_compact).
17859 (rotldi3, rotldi3_mextr, rotrdi3, rotrdi3_mextr): New patterns.
17860 (loaddi_trunc, zero_extendhisi2, zero_extendhisi2_media): Likewise.
17861 (zero_extendhisi2_media+1, zero_extendqisi2): Likewise.
17862 (zero_extendqisi2_media, extendhisi2, extendhisi2_media): Likewise.
17863 (extendhisi2_media, extendhisi2_media+1, extendqisi2): Likewise.
17864 (extendqisi2_media, extendqisi2_media+1, truncdisi2): Likewise.
17865 (truncdihi2, truncdiqi2, reload_inqi, reload_inhi): Likewise.
17866 (shmedia32_initialize_trampoline_big): Likewise.
17867 (shmedia32_initialize_trampoline_little): Likewise.
17868 (nsb, nsbsi, nsbdi, ffsdi2, ffssi2, byterev): Likewise.
17869 (negdi2): Remove spurious T clobber.
17870 (zero_extendhidi2+1, extendhidi2+1, extendqidi2+1): Handle TRUNCATE.
17871 (movsi_media, movsi_media_nofpu): Remove spurious *k after b.
17872 (movdi_media, movdi_media_nofpu, pt, ptb): Likewise.
17873 (movsi_media_nofpu+2, movhi_media+1): Only do split after reload.
17874 (ic_invalidate_line_media): Write back data cache before invalidating
17875 instruction cache. Add type.
17876 (movsf_media): Sign-extend when the destination is a general
17877 purpose register. Add type.
17878 (bgt_media, bge_media, bgtu_media, bgeu_media, blt_media_i): Allow 0.
17879 (casesi_worker_0+1): Only increment ref count for proper label.
17880 (casesi_worker_0+2): Likewise.
17881
7ca0873c
MM
178822002-07-09 Mark Mitchell <mark@codesourcery.com>
17883
17884 * dwarfout.c (dwarfout_init): Warn that DWARF1 is deprecated.
17885
26b10ae0 178862002-07-09 Steve Ellcey <sje@cup.hp.com>
7ca0873c 17887
26b10ae0
SE
17888 * gcc/except.c (expand_eh_region_end_cleanup): Change exception pointer
17889 from Pmode to ptr_mode.
17890 (get_exception_pointer): Ditto.
17891 (connect_post_landing_pads): Ditto.
17892 (dw2_build_landing_pads): Ditto.
17893
0c3a2ea0
SE
178942002-07-08 Steve Ellcey <sje@cup.hp.com>
17895 * gcc/c-pragma.h (add_to_renaming_pragma_list): New function.
17896 * gcc/c-pragma.c (add_to_renaming_pragma_list): New function.
17897 (handle_pragma_redefine_extname): Change to use new function.
17898
26c34780
RS
178992002-07-08 Roger Sayle <roger@eyesopen.com>
17900
17901 * combine.c (combine_simplify_rtx): Add an explicit cast
17902 to avoid signed/unsigned comparison warning.
17903 (simplify_if_then_else): Likewise.
17904 (extended_count): Likewise.
17905 (simplify_shift_const): Likewise.
17906 (simplify_comparison): Likewise.
17907
1d4047e0
RS
179082002-07-08 Richard Sandiford <rsandifo@redhat.com>
17909
17910 * config/mips/mips.md: Add imadd type. Update scheduler description
17911 to use imadd as well as imul.
17912 (*mul_acc_si, *madsi): Change imul alternatives to imadd.
17913 (*mul_acc_di, *mul_acc_64bit_di): Likewise.
17914 (*mul_sub_si): Likewise for first alternative. Change second
17915 alternative from imul to multi.
17916
5351f1ca
NB
179172002-07-07 Neil Booth <neil@daikokuya.co.uk>
17918
17919 * c-common.c (c_common_post_options): Update prototype;
17920 don't init backends if preprocessing only.
17921 * langhooks-def.h (LANG_HOOKS_POST_OPTIONS): Update.
17922 * langhooks.h (struct lang_hooks): Update post_options to
17923 return a boolean.
17924 * toplev.c (parse_options_and_default_flags, do_compile,
17925 lang_independent_init): Update prototypes. Allow the
17926 front end to specify that there is no need to initialize
17927 the back end.
17928 (general_init): Move call to hex_init here...
17929 (toplev_main): ...from here. Pass flag for back end init
17930 suppression.
17931
c8cc4417
R
17932Sun Jul 7 20:38:38 2002 J"orn Rennecke <joern.rennecke@superh.com>
17933
17934 * sh.h (PRINT_OPERAND_PUNCT_VALID_P): Allow '\''.
17935 (PREDICATE_CODES): Add entries for equality_comparison_operator,
17936 greater_comparison_operator and less_comparison_operator.
17937 * sh.c (print_operand): Add '\'' code. Make 'o' handle
17938 more operators.
17939 (equality_comparison_operator): New function.
17940 (greater_comparison_operator, less_comparison_operator): Likewise.
17941 * sh.md (beq_media_i): Disable generator function generation.
17942 Use match_operator to handle a whole class of comparisons. Add
17943 modifier in output template to provide branch prediction. Add type.
17944 (bgt_media_i, ble_media_i): Likewise. Allow zero operands.
17945 (bne_media_i, bge_media_i, bgtu_media_i, bgeu_media_i): Delete.
17946 (blt_media_i, bleu_media_i, bltu_media_i): Likewise.
17947 (bgt, blt, ble, bge, bgtu, bltu, bgeu, bleu): Allow zero operands.
17948
957ec0f9
HPN
179492002-07-07 Hans-Peter Nilsson <hp@bitrange.com>
17950
17951 Emit MMIX function prologue and epilogue as rtl.
17952 * config/mmix/mmix.md ("call"): Use mmix_get_hard_reg_initial_val,
17953 not unprototyped get_hard_reg_initial_val.
17954 ("call_value", "nonlocal_goto_receiver"): Ditto.
17955 ("return"): Make define_expand. Move real insn to...
17956 ("*expanded_return"): New pattern.
17957 ("prologue", "epilogue"): New define_expands.
17958 * config/mmix/mmix.h (MMIX_rO_REGNUM): New macro.
17959 (struct machine_function): New member in_prologue.
17960 (FIRST_PSEUDO_REGISTER): Adjust for including rO as register.
17961 (FIXED_REGISTERS, CALL_USED_REGISTERS): Ditto.
17962 (MMIX_MMIXWARE_ABI_REG_ALLOC_ORDER): Ditto.
17963 (MMIX_GNU_ABI_REG_ALLOC_ORDER, REG_CLASS_CONTENTS): Ditto.
17964 (REGISTER_NAMES, ADDITIONAL_REGISTER_NAMES): Ditto.
17965 (LOCAL_REGNO): Define. Adjust comment.
17966 * config/mmix/mmix.c (MMIX_CFUN_NEEDS_SAVED_EH_RETURN_ADDRESS):
17967 Consider regs_ever_live[MMIX_rJ_REGNUM], not just
17968 leaf_function_p.
17969 (MMIX_OUTPUT_REGNO): Don't translate registers while outputting
17970 the prologue.
17971 (mmix_target_asm_function_prologue): Make static. Just mark that
17972 the prologue is being emitted. Move guts to...
17973 (mmix_expand_prologue): New function. Adjust for emitting
17974 prologue as rtl. For sizes, use HOST_WIDE_INT only.
17975 (mmix_target_asm_function_epilogue): Make static. Simply emit a
17976 \n. Move guts to...
17977 (mmix_expand_epilogue): New function. Adjust for emitting
17978 epilogue as rtl. For sizes, use HOST_WIDE_INT only.
17979 (mmix_target_asm_function_end_prologue): Mark that the prologue
17980 has ended.
17981 (TARGET_ASM_FUNCTION_END_PROLOGUE): Define.
17982 (mmix_conditional_register_usage): Improve comments.
17983 (mmix_local_regno): New function.
17984 (mmix_emit_sp_add, mmix_get_hard_reg_initial_val): Ditto.
17985 * config/mmix/mmix-protos.h (mmix_local_regno): Prototype.
17986 (mmix_expand_prologue, mmix_expand_epilogue): Ditto.
17987 (mmix_get_hard_reg_initial_val): Ditto.
17988
7ab5c789
AJ
179892002-07-06 Andreas Jaeger <aj@suse.de>
17990
17991 * toplev.c (set_fast_math_flags): Don't use ISO C style function
17992 definitions.
17993 * gengtype.c (open_base_files): Likewise.
17994 (close_output_files): Likewise.
17995 * tracer.c (find_best_predecessor): Likewise.
17996 (find_best_successor): Likewise.
17997 (ignore_bb_p): Likewise.
17998
df061a43
RS
179992002-07-05 Roger Sayle <roger@eyesopen.com>
18000
18001 PR c++/7099
18002 * builtin-attrs.def: Define new attribute lists for use in
18003 builtins.def.
18004 * builtins.def [DEF_BUILTIN]: Modify to take an additional
18005 ATTRS argument, an enumerated value defined in builtin-attrs.def
18006 that represents the attribute list for the builtins. Modify
18007 all builtin functions to pass an appropriate attribute list.
18008 Specify "abort", "exit", "_exit" and "_Exit" builtins here with
18009 their required noreturn attributes.
18010 * tree.h (enum_builtin_function): Ignore the additional parameter
18011 to DEF_BUILTIN.
18012 * builtins.c (built_in_names): Likewise.
18013 * c-common.c: (builtin_function_2): Replace the "int noreturn_p"
18014 argument with a tree representing the functions attribute list.
18015 Pass this "attrs" argument to builtin_function. No longer handle
18016 the noreturn_p processing manually.
18017 (built_in_attributes): Move the definitions from builtin-attrs.def
18018 before c_common_nodes_and_builtins.
18019 (c_common_nodes_and_builtins): Handle the new ATTRS parameter in
18020 DEF_BUILTIN, passing it to both builtin_function and the changed
18021 builtin_function_2.
18022
18023 * doc/extend.texi: Document __builtin_abort, __builtin_exit,
18024 __builtin__exit and __builtin__Exit.
18025
e5eb8de8
SC
180262002-07-05 Stephane Carrez <stcarrez@nerim.fr>
18027
18028 * config/m68hc11/m68hc11.md ("*movqi_68hc12"): Avoid allocating
18029 QI mode registers in soft registers.
7ab5c789 18030 ("zero_extendqihi2"): Do not take into account soft registers
e5eb8de8
SC
18031 for register allocation (use '*' constraint).
18032
4c8aed14
SC
180332002-07-05 Stephane Carrez <stcarrez@nerim.fr>
18034
18035 * config/m68hc11/m68hc11.md ("*ashlsi3"): Avoid saving y if we know
18036 it is dead.
18037 ("*ashrsi3"): Likewise.
18038 ("*lshrsi3"): Likewise.
18039
99ed68ea
VM
180402002-07-05 Vladimir Makarov <vmakarov@redhat.com>
18041
18042 * genautomata.c (output_max_insn_queue_index_def): Take latencies
18043 into account.
18044
4c8aed14 180452002-07-05 Stephane Carrez <stcarrez@nerim.fr>
581fd392
SC
18046
18047 * config/m68hc11/m68hc11.md (peephole2): New peephole2 to optimize
18048 address computation and memory moves.
18049
9833f679
MM
180502002-07-03 Mark Mitchell <mark@codesourcery.com>
18051
18052 PR c++/6706
18053 * dwarfout.c (output_reg_number): Fix warning message.
18054 (output_bound_representation): Check SAVE_EXPR_RTL is not NULL
18055 before using it.
7ab5c789 18056
81bca2f5
RO
180572002-07-05 Rainer Orth <ro@TechFak.Uni-Bielefeld.DE>
18058
18059 * gcc/gcc.c (asm_debug): Move initialization ...
18060 (init_spec): ... here.
18061
17f44f02
NS
180622002-07-05 Nathan Sidwell <nathan@codesourcery.com>
18063
18064 * c-parse.in (extdef): Append ';'.
18065 (old_style_parm_decls): Append ';'.
18066
da77408f
DJ
180672002-07-04 Daniel Jacobowitz <drow@mvista.com>
18068
18069 * configure.in: Correct typos: gcc_cv_as_gdwarf2_debug_flag to
18070 gcc_cv_as_gdwarf2_flag and gcc_cv_as_gstabs_debug_flag
18071 to gcc_cv_as_gstabs_flag.
18072 * configure: Rebuilt.
18073
ec52b446
GK
180742002-07-04 Geoffrey Keating <geoffk@redhat.com>
18075
18076 * ggc.h (ggc_add_root): Document as obsolete.
18077
8721e3df
R
18078Thu Jul 4 07:58:01 2002 J"orn Rennecke <joern.rennecke@superh.com>
18079
18080 * sh.md (mshfhi_b, mshflo_b, mshfhi_l, mshflo_l, mshfhi_w): Add DONE.
18081 (mshflo_w): Likewise.
18082
3767c0fd
R
18083Thu Jul 4 07:36:29 2002 J"orn Rennecke <joern.rennecke@superh.com>
18084
18085 * simplify-rtx.c (simplify_subreg): Reduce problem of finding
18086 vector mode subregs of constants to finding integer mode
18087 subregs of constants.
18088 * cse.c (cse_insn): Use simplify_gen_subreg.
18089 * convert.c (convert_to_integer): Don't strip a NOP_EXPR
18090 From a vector mode expression of different size than the
18091 target mode.
18092
4e314d1f
EC
180932002-07-03 Eric Christopher <echristo@redhat.com>
18094
18095 * config/mips/linux.h: Add #undef for SUBTARGET_CPP_SPEC.
18096 * config/mips/mips.h: Remove deprecated -m<processor> options
18097 and cc1_cpu_spec associated.
18098 (CONSTANT_ADDRESS_P): Fix last patch.
18099 (ASM_DECLARE_FUNCTION_NAME): Declare. Fix comment.
18100 * config/mips/mips.md (bungt, bunge, sungt_df, sungt_sf, sunge_df,
18101 sunge_sf): Remove.
18102
6f0361e3
SS
181032002-07-03 Stan Shebs <shebs@apple.com>
18104
18105 * config/darwin.h (APPLE_CC): Remove, not meaningful in FSF GCC.
18106 (STRINGIFY_THIS, REALLY_STRINGIFY): Remove.
18107 (CPP_SPEC): Remove insertion of APPLE_CC definition.
18108
3129af4c
RS
181092002-07-03 Roger Sayle <roger@eyesopen.com>
18110
18111 * combine.c (struct_undo): Change types of recorded substitutions
18112 to be either "int" or "rtx", instead of "unsigned int" and "rtx".
18113 (do_SUBST_INT): Change types of the substitution from unsigned int
18114 to int, to avoid compilation warning from SUBST_INT's only caller.
18115
18116 (make_extraction): Add cast to avoid compilation warning.
18117 (force_to_mode): Remove cast to avoid compilation warning.
18118
c7375e61
EB
181192002-07-03 Eric Botcazou <ebotcazou@multimania.com>
18120 Jeff Law <law@redhat.com>
18121
18122 * i386.md (length_immediate attribute): Fix typo.
18123 (length_address attribute): Likewise.
18124 (modrm attribute): Set it to 0 for immediate call instructions.
18125 (jcc_1 pattern): Set modrm attribute to 0.
18126 (jcc_2 pattern ): Likewise.
18127 (jump pattern): Likewise.
18128 (doloop_end_internal pattern): Explicitly set length.
18129 (leave pattern): Fix typo.
18130 (leave_rex64 pattern): Likewise.
18131
61c07d3c
DE
181322002-07-03 David Edelsohn <edelsohn@gnu.org>
18133
18134 * config/rs6000/rs6000.md (fix_truncdfsi2_internal): Ignore DImode
18135 in FPR as preference.
18136 (fctiwz): Same.
18137 (floatdidf2, fix_truncdfdi2): Same.
18138 (floatdisf2, floatditf2, fix_trunctfdi2): Same.
18139 (floatditf2): Same.
18140 (floatsitf2, fix_trunctfsi2): SImode in GPR.
18141 (ctrdi): Remove FPR alternative and splitter.
18142
181432002-07-03 Will Cohen <wcohen@redhat.com>
77966be3
WC
18144
18145 * config/i386/i386.c (x86_integer_DFmode_moves): Disable for PPro.
18146
34a80643
R
18147Wed Jul 3 10:24:16 2002 J"orn Rennecke <joern.rennecke@superh.com>
18148
18149 * optabs.c (expand_vector_binop): Don't store using a SUBREG smaller
18150 than UNITS_PER_WORD, unless this is little endian and the first unit
18151 in this word. Let extract_bit_field decide how to load an element.
18152 Force arguments to matching mode.
18153 (expand_vector_unop): Likewise.
18154
18155 * simplify-rtx.c (simplify_subreg): Don't assume that all vectors
18156 consist of word_mode elements.
18157 * c-typeck.c (build_binary_op): Allow vector types for BIT_AND_EXPR,
18158 BIT_ANDTC_EXPR, BIT_IOR_EXPR and BIT_XOR_EXPR.
18159 (build_unary_op): Allow vector types for BIT_NOT_EPR.
18160 * emit-rtl.c (gen_lowpart_common): Use simplify_gen_subreg for
18161 CONST_VECTOR.
18162 * optabs.c (expand_vector_binop): Try to perform operation in
18163 smaller vector modes with same inner size. Add handling of AND, IOR
18164 and XOR. Reject expansion to inner-mode sized scalars when using
18165 OPTAB_DIRECT. Use simplify_gen_subreg on constants.
18166 (expand_vector_unop): Try to perform operation in smaller vector
18167 modes with same inner size. Add handling of one's complement.
18168 When there is no vector negate operation, try a vector subtract
18169 operation. Use simplify_gen_subreg on constants.
18170 * simplify-rtx.c (simplify_subreg): Add capability to convert vector
18171 constants into smaller vectors with same inner mode, and to
18172 integer CONST_DOUBLEs.
18173
622d3731
KG
181742002-07-02 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
18175
18176 * c-parse.in (parsing_iso_function_signature): New variable.
18177 (extdef_1): New, copied from...
18178 (extdef): ... here. Reset parsing_iso_function_signature.
18179 (old_style_parm_decls): Reset parsing_iso_function_signature.
18180 (old_style_parm_decls_1): New, copied from old_style_parm_decls.
18181 Warn about ISO C style function definitions.
18182 (nested_function, notype_nested_function): Reset
18183 parsing_iso_function_signature.
18184 (parmlist_2): Set parsing_iso_function_signature.
18185
18186 * doc/invoke.texi (-Wtraditional): Document new behavior.
18187
9bb46191
CD
181882002-07-02 Chris Demetriou <cgd@broadcom.com>
18189
18190 * config.gcc (mips*el-*-*): Use tm_defines to set
18191 TARGET_ENDIAN_DEFAULT, rather than including mips/little.h.
18192 * config/mips/little.h: Remove.
18193
e1c2dd26 181942002-07-02 Devang Patel <dpatel@apple.com>
c40da518 18195
c40da518 18196 * objc/objc-act.c (adjust_type_for_id_default): Do not allow an
31e25abd
CD
18197 object as parameter. Prevent something like 'NSObject' to be
18198 used as the type for a method argument.
c40da518 18199
0879540b
NB
182002002-07-03 Neil Booth <neil@daikokuya.co.uk>
18201
18202 * cpptrad.c: Update comment.
18203
b6fb43ab 182042002-07-02 Neil Booth <neil@daikokuya.co.uk>
4e314d1f 18205
b6fb43ab
NB
18206 * doc/cpp.texi: Update for traditional preprocessing changes.
18207 * goc/cppopts.texi: Similarly.
18208
c1c5187c
ZL
182092002-07-02 Ziemowit Laski <zlaski@apple.com>
18210
18211 * c-parse.in (designator): Enable designated initializers if ObjC.
18212 (objcmessageexpr): Remove references to objc_receiver_context.
18213 * objc/objc-act.h (objc_receiver_context): Remove decl.
18214 * objc/objc-act.c (objc_receiver_context): Remove.
18215 (lookup_objc_ivar): Test objc_method_context instead of
18216 objc_receiver_context.
18217
52702ae1
R
18218Tue Jul 2 18:45:45 2002 J"orn Rennecke <joern.rennecke@superh.com>
18219
18220 * sh.c (print_operand, case 'N'): Allow zero vector.
18221 (arith_reg_or_0_operand): Likewise.
18222 (zero_vec_operand): Check for CONST_VECTOR, not PARALLEL.
4e314d1f 18223 * sh.h (CONST_COSTS): 0 has 0 cost. Check OUTER_CODE for
52702ae1
R
18224 IOR, XOR, PLUS and SET and take their respective constant
18225 ranges into account.
18226 (PREDICATE_CODES, arith_reg_or_0_operand): Can be CONST_VECTOR.
18227 * sh.md (subdi3, subdi3_media): Allow zero operand.
18228 (movv8qi_i+3): Only vector that is not split is the zero vector.
18229 Fix operand 3 to simplify_subreg.
18230 (movv2si_i): Split alternative 1.
18231 (mshfhi_l_di_rev+1): New splitter.
18232
49e7b251
NB
182332002-07-02 Neil Booth <neil@daikokuya.co.uk>
18234
ba57a9c0 18235 PR preprocessor/7029
49e7b251
NB
18236 * cppinit.c (cpp_handle_option): Suppress warnings with an
18237 implicit "-w" for "-M" and "-MM".
18238 * doc/cppopts.texi: Update.
18239
a3acdc0c
RS
182402002-07-01 Roger Sayle <roger@eyesopen.com>
18241
18242 * config/sh/sh.c (sh_media_init_builtins): Change use of poisoned
18243 identifier "bzero" to "memset". Pass extra NULL_TREE argument to
18244 builtin_function.
18245
0b558962
AM
182462002-07-02 Alan Modra <amodra@bigpond.net.au>
18247
18248 * README.Portability: Fix typos.
18249
9a81c5b7
HPN
182502002-07-01 Hans-Peter Nilsson <hp@axis.com>
18251
18252 PR target/7177
18253 * config/cris/cris.h (LEGITIMIZE_RELOAD_ADDRESS): Correct number
18254 of indirections for register inside sign-extended mem part.
18255
6a2dd09a
RS
182562002-07-01 Roger Sayle <roger@eyesopen.com>
18257
18258 * tree.h: Modify builtin_function interface to take an extra
18259 argument ATTRS, which is a tree representing an attribute list.
18260
18261 * c-decl.c (builtin_function): Accept additional parameter.
18262 * objc/objc-act.c (builtin_function): Likewise.
18263 * f/com.c (builtin_function): Likewise.
18264 * java/decl.c (builtin_function): Likewise.
18265 * ada/utils.c (builtin_function): Likewise.
18266 * cp/decl.c (builtin_function): Likewise.
18267 (builtin_function_1): Likewise.
18268
18269 * c-common.c (c_common_nodes_and_builtins): Pass an additional
18270 NULL_TREE argument to builtin_function. (builtin_function_2):
18271 Likewise.
18272 * cp/call.c (build_java_interface_fn_ref): Likewise.
18273 * objc/objc-act.c (synth_module_prologue): Likewise.
18274 * java/decl.c (java_init_decl_processing): Likewise.
18275 * f/com.c (ffe_com_init_0): Likewise.
18276
18277 * config/alpha/alpha.c (alpha_init_builtins): Pass an additional
18278 NULL_TREE argument to builtin_function.
18279 * config/arm/arm.c (def_builtin): Likewise.
18280 * config/c4x/c4x.c (c4x_init_builtins): Likewise.
18281 * config/i386/i386.c (def_builtin): Likewise.
18282 * config/ia64/ia64.c (def_builtin): Likewise.
18283 * config/rs6000/rs6000.c (def_builtin): Likewise.
18284
e20569ae
ZW
182852002-07-01 Zack Weinberg <zack@codesourcery.com>
18286
18287 * config/ip2k/t-ip2k: Remove LIBGCC1, CROSS_LIBGCC1, and LIBGCC1_TEST.
18288 * config/mips/t-isa3264: Likewise.
18289 * config/mmix/t-mmix: Likewise.
18290
f1b690f1
JDA
182912002-07-01 John David Anglin <dave@hiauly1.hia.nrc.ca>
18292
18293 * emit-rtl.c (init_emit_once): Add missing cast to HOST_WIDE_INT.
18294
6bfa5aac
RS
182952002-07-01 Roger Sayle <roger@eyesopen.com>
18296
18297 PR opt/4046
18298 * fold-const.c (fold) [COND_EXPR]: Simplify A ? 0 : 1 to !A,
18299 A ? B : 0 to A && B and A ? B : 1 into !A || B if both A and
18300 B are truth values.
18301
9a5c1b9d
NN
183022002-07-01 Nathanael Nerode <neroden@gcc.gnu.org>
18303
18304 * config/mmix/t-mmix: Eliminate last reference to LIBGCC1_TEST.
18305
d3fc4dbc
MK
183062002-07-01 Matt Kraai <kraai@alumni.cmu.edu>
18307
3b2124df
MK
18308 * README.Portability (Function prototypes): Give an example of
18309 declaring and defining a function with no arguments.
18310
d3fc4dbc
MK
18311 * README.Portability (Function prototypes): Document new
18312 variable-argument function macros.
18313
c1b92d09
R
18314Mon Jul 1 19:55:17 2002 J"orn Rennecke <joern.rennecke@superh.com>
18315
18316 * sh.c (langhooks.h): Include.
18317 (sh_init_builtins, sh_media_init_builtins): New functions.
18318 (sh_expand_builtin, arith_reg_dest,and_operand): Likewise.
18319 (mextr_bit_offset, extend_reg_operand, zero_vec_operand): Likewise.
18320 (sh_rep_vec, sh_1el_vec, sh_const_vec): Likewise.
18321 (builtin_description): New struct tag.
18322 (signature_args, bdesc): New arrays.
18323 (TARGET_INIT_BUILTINS, TARGET_EXPAND_BUILTIN): Undef / define.
18324 (print_operand): Add 'N' modifier.
18325 * sh.h (VECTOR_MODE_SUPPORTED_P): Add SHmedia vector modes.
18326 (EXTRA_CONSTRAINT_U, EXTRA_CONSTRAINT_W): New macros.
18327 (EXTRA_CONSTRAINT): Add 'U' and 'W' cases.
18328 (CONST_COSTS): Add special case for SHmedia AND.
18329 (PREDICATE_CODES): Add and_operand, arith_reg_dest,
18330 extend_reg_operand, extend_reg_or_0_operand, mextr_bit_offset,
18331 sh_const_vec, sh_1el_vec, sh_rep_vec, zero_vec_operand.
18332 target_operand can also be const or unspec.
18333 * sh.md (UNSPEC_INIT_TRAMP, UNSPEC_FCOSA UNSPEC_FSRRA): New constants.
18334 (UNSPEC_FSINA, UNSPEC_NSB, UNSPEC_ALLOCO): Likewise.
18335 (attribute type): Add new types.
18336 (anddi3): Add splitter.
18337 (movdi_const_16bit+1): Add code to handle vector constants and
18338 bitmasks efficiently.
18339 (shori_media): Have generator function made.
18340 (movv8qi, movv8qi_i, movv8qi_i+1, movv8qi_i+2): New patterns.
18341 (movv8qi_i+3, movv2hi, movv2hi_i, movv4hi, movv4hi_i): Likewise.
18342 (movv2si, movv2si_i, absv2si2, absv4hi2, addv2si3, addv4hi3): Likewise.
18343 (ssaddv2si3, usaddv8qi3, ssaddv4hi3, negcmpeqv8qi): Likewise.
18344 (negcmpeqv2si, negcmpeqv4hi, negcmpgtuv8qi, negcmpgtv2si): Likewise.
18345 (negcmpgtv4hi, mcmv, mcnvs_lw, mcnvs_wb, mcnvs_wub): Likewise.
18346 (mextr_rl, mextr_lr, mextr1, mextr2, mextr3, mextr4, mextr5): Likewise.
18347 (mextr6, mextr7, mmacfx_wl, mmacfx_wl_i, mmacnfx_wl): Likewise.
18348 (mmacnfx_wl_i, mulv2si3, mulv4hi3, mmulfx_l, mmulfx_w): Likewise.
18349 (mmulfxrp_w, mmulhi_wl, mmullo_wl, mmul23_wl, mmul01_wl): Likewise.
18350 (mmulsum_wq, mmulsum_wq_i, mperm_w, mperm_w_little): LIkewise.
18351 (mperm_w_big, mperm_w0, msad_ubq, msad_ubq_i, mshalds_l): Likewise.
18352 (mshalds_w, ashrv2si3, ashrv4hi3, mshards_q, mshfhi_b): Likewise.
18353 (mshflo_b, mshf4_b, mshf0_b, mshfhi_l, mshflo_l, mshf4_l): Likewsie.
18354 (mshf0_l, mshfhi_w, mshflo_w, mshf4_w, mshf0_w, mshfhi_l_di): Likewise.
18355 (mshfhi_l_di_rev, mshflo_l_di, mshflo_l_di_rev): Likewise.
18356 (mshflo_l_di_x, mshflo_l_di_x_rev, ashlv2si3, ashlv4hi3): Likewise.
18357 (lshrv2si3, lshrv4hi3, subv2si3, subv4hi3, sssubv2si3): Likewise.
18358 (ussubv8qi3, sssubv4hi3, fcosa_s, fsina_s, fipr, fsrra_s): Likewise.
18359 (ftrv): Likewise.
18360
18361 (fpu_switch+1, fpu_switch+2): Remove constraint.
18362
97ebc06f
AH
183632002-07-01 Aldy Hernandez <aldyh@redhat.com>
18364
6c535c69
ZW
18365 * tree.c (build_function_type_list): Update function comment.
18366 Rename first argument to return_type.
97ebc06f 18367
353a10d0
NB
183682002-07-01 Neil Booth <neil@daikokuya.co.uk>
18369
18370 * Makefile.in: Remove all trace of tradcpp.c, tradcpp.h,
18371 tradcif.y and related files.
18372
e34cabb3
NB
183732002-07-01 Neil Booth <neil@daikokuya.co.uk>
18374
18375 * cpptrad.c (skip_whitespace): Pass pointer to prior char.
18376
8bf3ccbb
KG
183772002-07-01 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
18378
18379 * mips.h (FUNCTION_ARG_REGNO_P): Fix parentheses.
18380
44eedb75 18381See ChangeLog.7 for earlier changes.
This page took 2.417931 seconds and 5 git commands to generate.