1 2004-03-25 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
3 * builtins.c (fold_builtin): Fix error in last change.
5 2004-03-25 Richard Sandiford <rsandifo@redhat.com>
7 * config/mips/mips.h: Formatting fix.
9 2004-03-25 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
11 * builtins.def: Add ctype builtins.
12 * doc/extend.texi: Likewise.
14 2004-03-25 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
16 * builtins.c (fold_builtin): Add new builtin optimizations for
18 * fold-const.c (fold): Likewise.
20 2004-03-25 David Edelsohn <edelsohn@gnu.org>
22 * config/rs6000/rs6000.c (rs6000_always_hint): New variable.
23 (rs6000_sched_groups): New variable.
24 (processor_target_table): Add power5.
25 (rs6000_override_options): Set rs6000_sched_insert_nops,
26 rs6000_sched_costly_dep and rs6000_sched_restricted_insns_priority
27 from rs6000_sched_groups.
28 (output_cbranch): Use rs6000_always_hint.
29 (rs6000_variable_issue): Use rs6000_sched_groups.
30 (rs6000_adjust_cost): Add CPU_POWER5.
31 (is_microcoded_insn): Use rs6000_sched_groups.
32 (is_dispatch_slot_restricted): Use rs6000_sched_groups.
33 Return 2 for POWER5 cracked instructions.
34 (is_cracked_insn): Use rs6000_sched_groups.
35 (is_branch_slot_insn): Use rs6000_sched_groups.
36 (rs6000_issue_rate): Add CPU_POWER5.
37 (rs6000_sched_finish): Use rs6000_sched_groups.
38 (rs6000_rtx_costs): Add PROCESSOR_POWER5.
39 * config/rs6000/rs6000.h (processor_type): Add PROCESSOR_POWER5.
40 (DEFAULT_SCHED_COSTLY_DEP): Delete.
41 (DEFAULT_RESTRICTED_INSNS_PRIORITY): Delete.
42 (DEFAULT_SCHED_FINISH_NOP_INSERTION_SCHEME): Delete.
43 * config/rs6000/rs6000.md (define_attr "cpu"): Add power5.
44 * config/rs6000/power5.md: New file.
45 * doc/invoke.texi: Add power5 option.
47 2004-03-25 Kazu Hirata <kazu@cs.umass.edu>
49 * cfgrtl.c, dbxout.c, tree.def, config/darwin.h,
50 config/arm/arm.c, objc/objc-act.c: Fix comment typos.
51 * doc/invoke.texi: Fix a typo.
53 2004-03-25 Kazu Hirata <kazu@cs.umass.edu>
56 * stmt.c (emit_case_nodes): Emit equality comparisons instead
57 of recursing if both children are single-valued cases with no
60 2004-03-25 Paul Brook <paul@codesourcery.com>
62 * config/arm/arm.c (vfp_print_multi): Remove.
63 (arm_output_fldmx): New function.
64 (vfp_emit_fstmx): Return block size, not insn. Add ARM10 VFPr1 bugfix.
65 (arm_expand_prologue): Update to match.
66 (arm_get_vfp_saved_size): New Function.
67 (arm_get_frame_offsets): Use it.
68 (arm_output_epilogue): Use new functions.
70 2004-03-24 Richard Henderson <rth@redhat.com>
72 * alias.c (alias_invariant, alias_invariant_size): Mark GTY.
73 (reg_known_value, reg_known_value_size): Likewise; make static.
74 (reg_known_equiv_p): Make static.
75 (clear_reg_alias_info): Update for new indexing.
76 (get_reg_known_value, set_reg_known_value): New.
77 (get_reg_known_equiv_p, set_reg_known_equiv_p): New.
78 (canon_rtx): Use them.
79 (init_alias_analysis): Likewise. Allocate reg_known_value with gc.
80 Don't play queer offsetting games with reg_known_value and
82 (end_alias_analysis): Free reg_known_value with gc.
83 * rtl.h (get_reg_known_value, get_reg_known_equiv_p): Declare.
84 * sched-deps.c (reg_known_equiv_p, reg_known_value): Remove.
85 (deps_may_trap_p, sched_analyze_1, sched_analyze_2): Use the new
88 2004-03-24 Kazu Hirata <kazu@cs.umass.edu>
90 * dwarf2asm.c, loop.h, pretty-print.c, pretty-print.h,
91 config/i386/mmintrin.h: Update copyright.
93 2004-03-24 Nathanael Nerode <neroden@gcc.gnu.org>
95 * configure.ac: Add --enable-werror-always (for top level bootstrap
97 * configure: Regenerate.
99 2004-03-24 Ziemowit Laski <zlaski@apple.com>
101 * objc/objc-act.c (objc_comptypes): Treat comparisons
102 between 'Class' and '<class> *' as explicitly invalid.
104 2004-03-24 David Edelsohn <edelsohn@gnu.org>
106 * doc/invoke.texi (-frename-registers: Add enabled at -O3.
107 (-fprofile-values): Add enabled with profile-{generate,use}.
109 (-ftracer): Add enabled with profile-use.
110 (-funit-at-a-time): Add enabled at -O2,-O3.
111 (-funroll-loops): Add enabled with profile-use.
112 (-funswitch-loops): Add enabled with profile-use. Remove duplicates.
113 (max-gcse-passes): Mention default.
114 (max-cse-path-length): Mention default.
116 2004-03-24 Nathanael Nerode <neroden@gcc.gnu.org>
118 * Makefile.in (STRICT2_WARN): Reorder.
119 * configure.ac: Check for -Wold-style-definition, and use it
120 in strict1_warn if it's available.
121 * configure: Regnerate.
123 2004-03-24 Paul Brook <paul@nowt.org>
125 * config.gcc <arm>: Add --with-abi=
126 * config/arm/arm-protos.h (arm_get_frame_size, thumb_get_frame_size,
127 thumb_far_jump_used): Remove prototypes.
128 (arm_needs_doubleword_align): Add prototype.
129 (thumb_compute_initial_elimination_offset): Ditto.
130 * config/arm/arm.c (arm_get_frame_offsets): New function.
131 (use_return_insn, output_return_instruction, arm_output_epilogue,
132 arm_output_function_epilogue, arm_compute_initial_elimination_offset,
133 arm_expand_prologue, thumb_expand_epilogue): Use it.
134 (arm_abi, target_abi_name, all_arm_abis): New variables.
135 (arm_override_options): Set them. Set structure padding for AAPCS.
136 (arm_return_in_memory): Update ABI check.
137 (arm_init_cumulative_args): Initialize can_split.
138 (arm_needs_doubleword_align): New function.
139 (arm_function_arg): Don't split args after pushing to stack. Handle
140 doubleword/even reg alignment.
141 (arm_va_arg): Handle all doubleword aligned args.
142 (add_minpoolforward ref, dump_minpool, push_minpool_fix): Align based
144 (arm_compute_save_reg0_reg12_mask): Fix comment.
145 (thumb_get_frame_size, thumb_get_frame_size): Remove.
146 (thumb_jump_far_used_p): Remove superfluous argument. Return save
148 (thumb_unexpanded_epilogue, thumb_output_function_prologue): Change
150 (thumb_compute_initial_elimination_offset): New function.
151 (thumb_expand_prologue): Use arm_get_frame_offsets. Remove
152 unneccessary rounding.
153 * config/arm/arm.h (target_abi_name): Declare.
154 (ARM_DOUBLEWORD_ALIGN, DOUBLEWORD_ALIGNMENT, TARGET_IWMMXT_ABI,
155 arm_abi_type, ARM_DEFAULT_ABI): Define.
156 (ARM_FLAG_ATPCS): Remove.
157 (TARGET_OPTIONS, OPTION_DEFAULT_SPECS): Add -mabi=.
158 (BIGGEST_ALIGNMENT, PREFERRED_STACK_BOUNDARY, STACK_BOUNDARY): Use it.
159 (ADJUST_FIELD_ALIGN, DATA_ALIGNMENT, LOCAL_ALIGNMENT,
160 TYPE_NEEDS_IWMMXT_ALIGNMENT): Remove.
161 (LIBCALL_VALUE, FUNCTION_VALUE_REGNO_P, FUNCTION_ARG_REGNO_P):
162 Contitionalize on ABI, not CPU.
163 (struct arm_stack_offsets): Define.
164 (struct machine_function): Add stack_offsets. Remove frame_size.
165 (FUNCTION_ARG_PARTIAL_NREGS): Don't split if previous args have been
167 (FUNCTION_ARG_ADVANCE, FUNCTION_ARG_BOUNDARY): Handle general
168 doubleword alignment.
169 (THUMB_INITIAL_ELIMINATION_OFFSET,
170 ARM_INITIAL_ELIMINATION_OFFSET): Remove.
171 (INITIAL_ELIMINATION_OFFSET): Call functions directly.
172 * config/arm/arm.md (align_8): Enable for all targets.
173 * config/arm/netbsd-elf.h (TARGET_DEFAULT): Remove TARGET_ATPCS.
174 (ARM_DEFAULT_ABI): Define.
175 * doc/invoke.texi <ARM>: Document -mabi=. Update documentation for
176 -mstructure-size-boundary.
178 2004-03-24 Nathanael Nerode <neroden@gcc.gnu.org>
180 * configure.ac: Check for -Wno-variadic-macros; don't use
181 -pedantic (in stage 1 or a simple 'make all') unless it's available,
182 and if it's available, use it. Also, clean up check for
184 * configure: Regenerate.
186 2004-03-24 Richard Sandiford <rsandifo@redhat.com>
188 * config.gcc (mips64vr-*-elf*, mips64vrel-*-elf*): Remove tm_defines.
189 * config/mips/vr.h (DEFAULT_VR_ARCH): New macro, defined to vr4130.
190 (MULTILIB_DEFAULTS): Use it.
191 (MIPS_CPU_STRING_DEFAULT): Remove.
192 (MIPS_ABI_DEFAULT, MIPS_MARCH_CONTROLS_SOFT_FLOAT): Define.
193 (DRIVER_SELF_SPECS): Make -mfix-vr4122-bugs imply -march=vr4120. Make
194 EABI64 -mlong32 the default ABI. Enforce the default architecture.
195 * config/mips/t-vr (MULTILIB_OPTIONS): Add mfix-vr4122-bugs,
196 march=vr4130, march=vr4300, march=vr5000 and march=vr5500.
197 (MULTILIB_MATCHES): Use -mfix-vr4122-bugs multilibs for -march=vr4120.
198 (MULTILIB_EXCEPTIONS): Change choice of multilibs. Update comments
201 2004-03-24 DJ Delorie <dj@redhat.com>
202 Richard Sandiford <rsandifo@redhat.com>
204 * config/mips/mips.h (MASK_FIX_VR4122, TARGET_FIX_VR4122): New macros.
205 (TARGET_SWITCHES): Add -mfix-vr4122-bugs and -mno-fix-vr4122-bugs.
206 (ASM_SPEC): Pass down -mfix-vr4122-bugs.
207 * config/mips/mips.c (mips_avoid_hazards): Don't emit whole functions
208 in .set noreorder and .set nomacro if TARGET_FIX_VR4122.
209 (mips_init_libfuncs): Use special functions for divsi3 and modsi3
210 if TARGET_FIX_VR4122.
211 * config/mips/mips.md (define_attr length): Account for nops inserted
212 after macc and dmult when using -mfix-vr4122-bugs.
213 (umuldi3_highpart, divmodsi4, divmoddi4): Disable if TARGET_FIX_VR4122.
214 * config/mips/t-vr (LIB2FUNCS_STATIC_EXTRA): Define instead of
215 LIB2FUNCS_EXTRA. Add config/mips/vr4122-div.S.
216 * config/mips/vr4122-div.S: New file.
217 * doc/invoke.texi: Document -mfix-vr4122-bugs.
219 2004-03-24 Richard Sandiford <rsandifo@redhat.com>
221 * config/mips/mips.h (PROCESSOR_R4130): New processor_type.
222 (TARGET_MIPS4130): New macro.
223 (ISA_HAS_MACC): Return true if TARGET_MIPS4130 && !TARGET_MIPS16.
224 * config/mips/mips.c (mips_cpu_info_table): Add a vr4130 entry.
225 (override_options): Extend MIPS_MARCH_CONTROLS_SOFT_FLOAT to deal
226 with PROCESSOR_R4130.
227 * config/mips/mips.md (define_attr cpu): Add r4130.
228 * doc/invoke.texi: Document vr4130 as a supported MIPS architecture.
230 2004-03-24 Maciej W. Rozycki <macro@ds2.pg.gda.pl>
231 Richard Sandiford <rsandifo@redhat.com>
233 * doc/invoke.texi: Apply missed hunk from 2004-03-03 change.
235 2004-03-24 Alexandre Oliva <aoliva@redhat.com>
237 PR preprocessor/14438
238 * cpplib.c (do_pragma): Remove line_change call after pragma
241 2004-03-23 Ian Lance Taylor <ian@wasabisystems.com>
243 * doc/extend.texi (ARM Built-in Functions): Replace with correct
246 2004-03-23 Roger Sayle <roger@eyesopen.com>
248 * reg-stack.c (get_true_reg): Handle FLOAT_TRUNCATE like FLOAT_EXTEND
249 if flag_unsafe_math_optimizations.
250 * config/i386/i386.md (truncdfsf2): If flag_unsafe_math_optimizations
251 and TARGET_80387 expand using truncdfsf2_noop pattern.
252 (truncxfsf2): Likewise using truncxfsf2_noop.
253 (truncxfdf2): Likewise using truncxfdf2_noop.
254 (truncdfsf2_noop, truncxfsf2_noop, truncxfdf2_noop): New patterns.
256 2004-03-23 Ziemowit Laski <zlaski@apple.com>
258 * hooks.c (hook_constcharptr_tree_null): New hook.
259 * hooks.h (hook_constcharptr_tree_null): New prototype.
260 * target-def.h (TARGET_MANGLE_FUNDAMENTAL_TYPE): New target hook.
261 * target.h (mangle_fundamental_type): New target hook.
262 * config/rs6000/rs6000.c (TARGET_MANGLE_FUNDAMENTAL_TYPE): Point
263 target hook at rs6000_mangle_fundamental_type.
264 (rs6000_mangle_fundamental_type): New function.
265 * doc/tm.texi (TARGET_MANGLE_FUNDAMENTAL_TYPE): Document.
267 2004-03-23 Zack Weinberg <zack@codesourcery.com>
269 PR 12267, 12391, 12560, 13129, 14114, 14133
270 * c-tree.h: Forward declare struct c_binding. Declare
271 c_override_bindings_to_false. Update prototypes.
272 (struct lang_identifier): Update comments. Change fields to be
274 (IDENTIFIER_SYMBOL_VALUE, IDENTIFIER_TAG_VALUE)
275 (IDENTIFIER_LABEL_VALUE, C_DECL_INVISIBLE)
276 (KEEP_NO, KEEP_YES, KEEP_MAYBE): Delete.
277 (C_DECL_IN_EXTERNAL_SCOPE, C_DECL_DECLARED_BUILTIN): New.
278 * c-common.h: Update prototypes.
279 * c-decl.c (struct c_scope): Update commentary. Remove names,
280 names_last, parms, parms_last, tags, and shadowed fields. Add
281 bindings and depth fields.
282 (scope_freelist): Move to more appropriate location.
283 (c_print_identifier): Update for changes to struct lang_identifier.
284 (objc_mark_locals_volatile): Update for new bindings structures.
285 (global_bindings_p): Honor c_override_global_bindings_to_false.
286 (pushlevel): Rename to push_scope; take no arguments; use the
287 scope_freelist; initialize scope->depth and check for overflow.
288 (poplevel): Rename to pop_scope; totally rewritten for new bindings
290 (diagnose_mismatched_decls): Use C_DECL_DECLARED_BUILTIN, not
291 C_DECL_INVISIBLE, for certain decisions. Adjust some diagnostics.
292 Improve some commentary. Adjust handling of forward parm decls.
293 (merge_decls): Set C_DECL_DECLARED_BUILTIN when appropriate.
294 Preserve C_DECL_IN_EXTERNAL_SCOPE.
295 (warn_if_shadowing): Correct indentation. Improve diagnostics.
296 (pushdecl): Remove unnecessary assertion. Short-circuit anonymous
297 decls. Rewrite for new bindings structures. Improve commentary.
298 Eliminate the copy_node call.
299 (implicit_decl_warning): Use the "diag" idiom (as seen in
300 locate_old_decl) to reduce code duplication; call locate_old_decl
301 if appropriate. Relocate to remove need for forward declaration.
302 (implicitly_declare): Adjust for new bindings structures. Kludge
303 around Objective-C not-really-builtin functions.
304 (undeclared_variable): Improve diagnostics. If current_function_decl
305 is nonnull but current_function_scope is null, use current_scope.
307 (lookup_tag): Adjust for new bindings structures. Kludge around
308 Objective-C's tag declarations that wind up in the external scope.
309 (lookup_name): Adjust for new bindings structures. Kludge around
310 c-common.c's pseudo-typedefs that wind up in the external scope.
311 (lookup_name_current_level): Rename lookup_name_in_scope; take a
312 second argument indicating the scope to examine; rewrite for
313 new bindings structures.
314 (c_init_decl_processing): Adjust for renamed functions. Do not
315 initialize current_file_decl, first_builtin_decl, last_builtin_decl.
316 First scope pushed is the external scope, not the global scope.
317 (builtin_function): Use bind, not pushdecl. Adjust other bits
318 for new data structures. Keep track of builtins that should be
319 made visible automatically.
320 (start_decl): Adjust diagnostics. Remove unnecessary call to
322 (grokparms): Return 0 if arg_types is error_mark_node.
323 (get_parm_info): Rename "void_at_end" argument to "ellipsis", with
324 reversed sense. Rewrite for new bindings structures. Do not
325 leave any decls in the scope, to prevent pop_scope from doing
326 contradictory things with them.
327 (finish_struct, finish_enum): Remove redundant diagnostics.
328 (build_enumerator): Don't cascade diagnostics for error_mark_node.
329 Mark location where -pedantic changes the meaning of the program.
330 (store_parm_decls_newstyle, store_parm_decls_oldstyle): Load the
331 parameter decls into the function's scope structure using bind.
332 Warn here about function definitions in the wrong style.
334 (store_parm_decls): Correct the determination of whether a
335 function was defined with a prototype.
336 (c_write_global_declarations): Operate on all file decls and on
337 the external scope. Split body of the loop to...
338 (c_write_global_declarations_1): ... this new function, to avoid
340 (truly_local_externals, first_builtin_decl, last_builtin_decl)
341 (make_scope, pop_scope, in_parm_level_p, set_block)
342 (any_external_decl, record_external_decl, bind_label, getdecls)
343 (link_hash_hash, link_hash_eq, merge_translation_unit_decls)
344 (c_reset_state): Delete.
345 (visible_builtins, c_override_global_bindings_to_false)
346 (c_binding, I_SYMBOL_BINDING, I_SYMBOL_DECL, I_TAG_BINDING)
347 (I_TAG_DECL, I_LABEL_BINDING, I_LABEL_DECL, file_scope)
348 (external_scope, binding_freelist, bind, free_binding_and_advance)
349 (push_file_scope, pop_file_scope): New.
350 (pushtag, pushdecl_top_level, lookup_label, declare_label)
351 (define_label, c_make_fname_decl, finish_decl)
352 (mark_forward_parm_decls, build_compound_literal)
353 (grokdeclarator, start_function, check_for_loop_decls)
354 (identifier_global_value, record_builtin_type): Minor adjustments
355 for new bindings structures. Improve diagnostics and commentary.
356 * c-objc-common.c (start_cdtor, finish_cdtor): Adjust calls to
357 pushlevel/poplevel respectively.
358 (c_objc_common_finish_file): Don't call merge_translation_unit_decls.
359 * c-opts.c (c_common_parse_file): Remove spurious ATTRIBUTE_UNUSED.
360 Warn about YYDEBUG not being defined only if -dy. Remove no-longer-
361 correct loop over multiple translation units; call fatal_error if
362 requested to compile more than one file at once. (This disables
363 IMA temporarily - an up-front error being preferable to a crash.)
364 * c-parse.in (pushlevel, poplevel rules): Rename push_scope, pop_scope.
365 (all actions): Adjust calls to pushlevel/poplevel.
366 (parsing_iso_function_signature): Delete.
367 (extdef_1): Fold into extdef.
368 (old_style_parm_decls_1): Fold into old_style_parm_decls. Don't
369 warn here about function definitions in the wrong style.
370 (after_tyle_declarator, parm_declarator_starttypename)
371 (parm_declarator_nostarttypename, notype_declarator): Remove
372 commented-out productions.
373 (parmlist_1, parmlist_2): Use make_node, not tree_cons, to create
374 an empty TREE_LIST node. Adjust calls to get_parm_info.
375 (parmlist_2 : ELLIPSIS): Tag the arg-info block with error_mark_node
376 to suppress -Wold-style-definition after this error.
377 (c_parse_file): Don't clear the binding stack or call
378 finish_fname_decls here. Correct comment.
379 * c-typeck.c (same_translation_unit_p): Export.
380 (common_type): Use c_override_global_bindings_to_false, not
381 pushlevel/poplevel/declare_parm_level.
382 * c-lang.c: Override LANG_HOOKS_CLEAR_BINDING_STACK,
383 LANG_HOOKS_PUSHLEVEL, LANG_HOOKS_POPLEVEL, LANG_HOOKS_SET_BLOCK,
384 and LANG_HOOKS_GETDECLS with do-nothing stubs.
385 * objc/objc-lang.c: Likewise.
386 * objc/objc-act.c: Adjust all calls to pushlevel, poplevel,
388 (OBJC_VOID_AT_END): Delete; replace all uses
390 (generate_forward_declaration_to_string_table): Delete.
391 * objc/objc-act.h (OCTI_STRG_DECL, UOBJC_STRINGS_decl): Delete.
393 * coverage.c (create_coverage): Don't pushdecl anything.
394 * langhooks.c (lhd_clear_binding_stack): Call
395 lang_hooks.decls.poplevel, not poplevel.
396 * tree.c (list_length): If ENABLE_TREE_CHECKING, abort on a
397 circular list rather than going into an infinite loop.
399 2004-03-23 Olivier Hainque <hainque@act-europe.fr>
401 * optabs.c (expand_binop): When synthesizing double word rotates
402 from single word shifts, use a new register target if the provided
403 target is not a REG already.
405 2004-03-23 Richard Kenner <kenner@vlsi1.ultra.nyu.edu>
407 * alias.c (get_alias_set): Add support for TYPE_REF_CAN_ALIAS_ALL.
408 * c-common.c (handle_mode_attribute): Add extra arg to
409 build_pointer_type_for_mode and build_reference_type_for_mode.
410 * c-typeck.c (build_c_cast): Only look at TREE_CONSTANT_OVERFLOW
412 * tree.c (build_pointer_type_for_mode): Add arg CAN_ALIAS_ALL.
413 Chain pointers via TYPE_NEXT_PTR_TO.
414 (build_reference_type_for_mode): Similarly.
415 (build_type_no_quals): Add extra arg to build_pointer_type_for_mode
416 and build_reference_type_for_mode.
417 (tree_check4_failed): New function.
418 * tree.h (TREE_CHECK4, PTR_OR_REF_CHECK): New macros.
419 (TYPE_REF_CAN_ALIAS_ALL, TYPE_NEXT_PTR_TO, TYPE_NEXT_REF_TO): Likewise.
420 (TREE_NO_UNSUED_WARNING, TREE_VIA_VIRTUAL, TREE_CONSTANT_OVERFLOW):
423 2004-03-23 Roger Sayle <roger@eyesopen.com>
425 * fold-const.c (tree_expr_nonnegative_p): A&B is nonnegative when
426 A is nonnegative or B is nonnegative. Similarly A|B is nonnegative
427 when both A and B are nonnegative.
428 (tree_expr_nonzero_p): A|B is nonzero when A is nonzero or B is
431 2004-03-23 Kazu Hirata <kazu@cs.umass.edu>
433 * fold-const.c (fold): Remove cases for INTEGER_CST, REAL_CST,
434 VECTOR_CST, STRING_CST, COMPLEX_CST, and CONSTRUCTOR.
436 2004-03-23 Kazu Hirata <kazu@cs.umass.edu>
438 PR optimization/14669
439 * fold-const.c (fold): Only unwiden integer comparisons for equality
440 and inequality operators, or when the signedness doesn't change.
442 2004-03-23 Jakub Jelinek <jakub@redhat.com>
444 * config.gcc (sparc-*-linux*): Add sparc/t-linux to tmake_file.
445 * config/sparc/t-linux64 (TARGET_LIBGCC2_CFLAGS): Set.
446 * config/sparc/t-linux: New file.
448 2004-03-23 Richard Sandiford <rsandifo@redhat.com>
450 * gcse.c (can_assign_to_reg_p): New function, split out from...
451 (want_to_gcse_p): ...here.
452 (compute_ld_motion_mems): Use can_assign_to_reg_p to validate
455 2004-03-22 Diego Novillo <dnovillo@redhat.com>
457 * c-typeck.c (same_translation_unit_p): Fix pasto.
459 2004-03-22 David Edelsohn <edelsohn@gnu.org>
461 * params.def (PARAM_MAX_SCHED_REGION_BLOCKS): New.
462 (PARAM_MAX_SCHED_REGION_INSNS): New.
463 * sched-rgn.c: Include params.h
464 (MAX_RGN_BLOCKS): Delete.
465 (MAX_RGN_INSNS): Delete.
466 (too_large): Return bool. Convert to PARAM_VALUE.
467 * Makefile.in (sched-rgn.o): Depend on $(PARAMS_H).
468 * doc/invoke.texi (param): Document max-sched-region-blocks and
469 max-sched-region-insns.
471 2004-03-22 Joel Brobecker <brobecker@gnat.com>
473 * dwarf2out.c (is_subrange_type): Do not emit a subrange_type DIE
476 2004-03-22 Joel Brobecker <brobecker@gnat.com>
478 * dwarf2out.c (is_subrange_type): Minor code rework. No behavior
481 2004-03-22 Jakub Jelinek <jakub@redhat.com>
484 * c-decl.c (finish_struct): Change type of incorrect flexible array
485 field into error_mark_node.
487 2004-03-22 Andrew Pinski <pinskia@physics.uc.edu>
490 * config/rs6000/rs6000.c (symbol_ref_operand): Reject symbols
491 who are not local for Darwin PIC.
493 2004-03-22 Ulrich Weigand <uweigand@de.ibm.com>
495 * regrename.c (regrename_optimize): Set regs_ever_live for all
496 registers introduced as replacement.
498 2004-03-22 Eric Botcazou <ebotcazou@libertysurf.fr>
501 * expr.c (mark_queue): New function.
502 (emit_insns_enqueued_after_mark): New function replacing
503 emit_queue. Clear the body of emitted queued insns.
504 (emit_queue): Call emit_insns_enqueued_after_mark.
505 (store_expr): Mark the increment queue on entry. Emit
506 only the incrementations queued when expanding the source.
508 2004-03-22 Nathanael Nerode <neroden@gcc.gnu.org>
510 * configure.ac: Allow --disable-coverage-flags (for the future benefit
511 of top level bootstrap, and consistency). Reindent.
512 * configure: Regenerate.
514 2004-03-21 Kazu Hirata <kazu@cs.umass.edu>
516 * bt-load.c, builtins.c, cfghooks.c, cfgrtl.c, gcse.c,
517 ggc-page.c, integrate.c, var-tracking.c, web.c: Remove
520 2004-03-22 Danny Smith <dannysmith@users.sourceforge.net>
523 * gcov-io.h (gcov_truncate): Define ftruncate as _chsize for
526 2004-03-21 Ulrich Weigand <uweigand@de.ibm.com>
528 * config/s390/s390.md ("*doloop_si"): Change predicate for operand 2
529 to nonimmediate_operand.
530 ("*doloop_di"): Likewise.
532 2004-03-21 Alexandre Oliva <aoliva@redhat.com>
534 * real.h (struct real_value): Use the same type for all
535 bitfields. Rename exp to uexp.
536 (REAL_EXP, SET_REAL_EXP): New accessor macros for uexp.
537 Adjust all uses of exp...
538 * builtins.c: ... here, ...
539 * emit-rtl.c: ... here, and ...
540 * real.c: ... and here.
542 2004-03-21 Gabriel Dos Reis <gdr@integrable-solutions.net>
544 * pretty-print.c (pp_base_maybe_space): New function.
545 * pretty-print.h (pp_base_maybe_space): Declare.
546 (pp_maybe_space): New macro.
548 2004-03-21 Ulrich Weigand <uweigand@de.ibm.com>
550 * config/s390/s390.md ("addti3", "subti3"): New insns and splitters.
552 2004-03-21 Ulrich Weigand <uweigand@de.ibm.com>
554 * expmed.c (choose_mult_variant): Pass MULT_COST as argument instead
555 of using register multiplication cost.
556 (expand_mult): Adapt choose_mult_variant call.
557 (expand_mult_highpart): Call choose_mult_variant with WIDER_MODE
558 of MODE; pass appropriate cost bound. Adjust result when
559 performing signed multiplication by a negative constant.
560 Don't use intermediate modes larger than word_mode.
562 2004-03-21 Richard Kenner <kenner@vlsi1.ultra.nyu.edu>
564 * alias.c (get_alias_set): Remove handling of PLACEHOLDER_EXPR.
565 * emit-rtl.c (component_ref_for_mem_expr): Likewise.
566 (set_mem_attributes_minus_bitpos): Call SUBSTITUTE_PLACEHOLDER_IN_EXPR.
567 * explow.c (expr_size): Likewise.
568 * expr.h (placeholder_list, find_placeholder): Deleted.
569 * expr.c (store_constructor): Likewise.
570 (get_inner_reference): Likewise. Also don't call find_placeholder.
571 (placeholder_list, find_placeholder): Deleted.
572 (is_aligning_offset): Don't handle WITH_RECORD_EXPR, PLACEHOLDER_EXPR.
573 (expand_expr_real, cases PLACEHOLDER_EXPR, WITH_RECORD_EXPR): Likewise.
574 (highest_pow2_factor, case WITH_RECORD_EXPR): Remove.
575 * dojump.c (do_jump, case WITH_RECORD_EXPR): Likewise.
576 * dwarf2out.c (loc_descriptor_from_tree, case WITH_RECORD_EXPR):
578 * fold-const.c (invert_truthvalue, case WITH_RECORD_EXPR): Likewise.
579 (extract_muldiv, case WITH_RECORD_EXPR): Likewise.
580 * tree.c (expr_align, case WITH_RECORD_EXPR): Likewise.
581 (contains_placeholder_p): Don't handle WITH_RECORD_EXPR.
582 Clean up by using first_rtl_op.
583 (substitute_in_expr): Use SUBSTITUTE_IN_EXPR for recursive call.
584 (substitute_placeholder_in_expr): New function.
585 * tree.def (WITH_RECORD_EXPR): Deleted.
586 * tree.h (SUBSTITUTE_IN_EXPR, SUBSTITUTE_PLACEHOLDER_IN_EXPR): New.
587 (substitute_placeholder_in_expr): New.
589 2004-03-21 Andrew Pinski <pinskia@gcc.gnu.org>
591 * dojump.c (prefer_and_bit_test): Fix which part of
592 the and_test is replaced.
594 2004-03-21 Joseph S. Myers <jsm@polyomino.org.uk>
596 * frontends.texi: Add missing line.
598 2004-03-21 Zack Weinberg <zack@codesourcery.com>
599 Chris Devers <cdevers@pobox.com>
600 Joseph S. Myers <jsm@polyomino.org.uk>
602 * doc/frontends.texi: Rewrite.
603 * doc/gcc.texi: Update last modification date.
605 2004-03-21 Josef Zlomek <zlomekj@suse.cz>
607 * cfgrtl.c (cfg_layout_redirect_edge_and_branch): Print the debug
608 message before redirecting the edge.
610 2004-03-20 Zdenek Dvorak <rakdver@atrey.karlin.mff.cuni.cz>
612 * emit-rtl.c (set_mem_attributes_minus_bitpos): Set MEM_POINTER
614 * explow.c (force_not_mem): Set REG_POINTER flag according to
616 * rtl.h (MEM_POINTER): New macro.
617 (struct rtx_def): Use integrated for MEM_SCALAR_P and frame_related
620 2004-03-20 Roger Sayle <roger@eyesopen.com>
623 * cse.c (fold_rtx): Avoid substituting constants into unary
624 conversion operations.
626 2004-03-20 Kazu Hirata <kazu@cs.umass.edu>
628 * fold-const.c (fold): Replace "expr" with "t".
630 2004-03-20 Ian Lance Taylor <ian@wasabisystems.com>
633 * c-typeck.c (tagged_types_tu_compatible_p): Don't use
634 DECL_ORIGINAL_TYPE if there isn't one.
636 2004-03-20 Kazu Hirata <kazu@cs.umass.edu>
638 * fold-const.c (fold): Replace "final_type" with "type".
639 Remove variable "final_type".
641 2004-03-20 Kazu Hirata <kazu@cs.umass.edu>
643 * fold-const.c (fold): Constify "type".
644 Replace "TREE_TYPE (t)" with "type".
646 2004-03-20 Kazu Hirata <kazu@cs.umass.edu>
648 * bb-reorder.c, bt-load.c, c-decl.c, cfgcleanup.c, coverage.c,
649 dwarf2asm.c, ifcvt.c, stor-layout.c, varasm.c: Replace calls
650 via (*targetm.foo) () with targetm.foo ().
652 2004-03-20 Joseph S. Myers <jsm@polyomino.org.uk>
655 * doc/install.texi: Add info directory category and entry.
657 2004-03-20 Kazu Hirata <kazu@cs.umass.edu>
659 * fold-const.c (fold): Replace "t" with "tem" where it is used
660 as a temporary variable. Remove "orig_t" and all of its uses.
662 2004-03-20 Kazu Hirata <kazu@cs.umass.edu>
664 * fold-const.c (fold): Remove variable "invert".
665 Move the handling of relational expressions that can be folded
667 (fold_relational_const): ... here.
668 (tree_expr_nonzero_p): New.
670 2004-03-20 Joseph S. Myers <jsm@polyomino.org.uk>
673 * builtins.def (nan, nanf, nanl, nans, nansf, nansl): Change to
676 2004-03-20 Richard Sandiford <rsandifo@redhat.com>
678 * Makefile.in (dojump.o): Depend on $(GGC_H) and dojump.h.
679 (GTFILES): Add $(srcdir)/dojump.h.
680 (gt-dojump.h): New dependency.
681 * dojump.c (and_reg, and_test, shift_test): New static variables.
682 (prefer_and_bit_test): New function.
683 (do_jump): Use it to choose between (X & (1 << C)) and (X >> C) & 1.
685 2004-03-20 Kazu Hirata <kazu@cs.umass.edu>
687 * c-common.c, cfgcleanup.c, cgraphunit.c, c-pretty-print.c,
688 expmed.c, ggc-common.c, jump.c, passes.c, recog.c, regmove.c,
689 reorg.c, tree.h: Fix comment typos.
691 2004-03-19 Kazu Hirata <kazu@cs.umass.edu>
693 * alias.c, attribs.c, bt-load.c, builtins.c, c-common.c,
694 c-decl.c, c-objc-common.c, c-typeck.c, calls.c, cfglayout.c,
695 cse.c, dbxout.c, dwarf2out.c, except.c, final.c,
696 haifa-sched.c, integrate.c, passes.c, rtlanal.c, sched-rgn.c,
697 sched-vis.c, simplify-rtx.c, stor-layout.c, tree.c, varasm.c,
698 vmsdbgout.c: Replace calls via (*targetm.foo) () with
701 2004-03-19 Ziemowit Laski <zlaski@apple.com>
703 * config/rs6000/altivec.h (vec_dst, vec_dstst, vec_dststt,
704 vec_dstt, vec_sld, vec_splat): Add prototypes, marked with
705 always_inline attribute.
706 * config/rs6000/rs6000.c (altivec_expand_dst_builtin):
707 Treat expansion as completed even if literal argument is
708 invalid (so that other expansions are not tried in vain).
710 2004-03-19 Kazu Hirata <kazu@cs.umass.edu>
712 * loop-doloop.c (add_test): Replace GEN_INT (0) with
715 2004-03-19 Kazu Hirata <kazu@cs.umass.edu>
717 * fold-const.c (fold) <ABS_EXPR>: Move the handling of constants
719 (fold_abs_const): ... here.
721 2004-03-19 Richard Kenner <kenner@vlsi1.ultra.nyu.edu>
723 * tree.h (TYPE_ARRAY_MAX_SIZE): Use type.maxval directly.
725 2004-03-19 Denis Chertykov <denisc@overta.ru>
728 * config/avr/avr.md ("call_insn"): Handle explicit integer
730 (call_value_insn): Likewise.
732 2004-03-19 Richard Kenner <kenner@vlsi1.ultra.nyu.edu>
734 * tree.c (substitute_in_expr): Rewrite to simplify and be more generic.
736 2004-03-19 Kazu Hirata <kazu@cs.umass.edu>
738 * fold-const.c (negate_expr): Move the handling of constants
740 (fold_negate_const): ... here.
742 2004-03-19 Richard Kenner <kenner@vlsi1.ultra.nyu.edu>
744 * langhooks-def.h (LANG_HOOKS_HASH_TYPES): New macro and hook.
745 * langhooks.h (struct lang_hooks_for_types): New field hash_types.
746 * tree.c (debug_no_type_hash): Deleted.
747 (type_hash_canon): Abort if passed a variant.
748 Check lang_hooks.types.hash_types.
749 (build_type_no_quals): Copy mode of POINTER_TYPE and REFERENCE_TYPE.
750 (build_array_type): Remove unnecessary allocation of pointer type.
751 (build_complex_type): Properly qualify resulting type.
753 2004-03-19 Paolo Bonzini <bonzini@gnu.org>
755 * config/rs6000/rs6000.c (rs6000_init_builtins): Fix typo.
757 2004-03-19 Richard Sandiford <rsandifo@redhat.com>
759 * expmed.c (choose_mult_variant, expand_mult_const): New, split from...
760 (expand_mult): ...here.
761 (extract_high_half): New, split out from expand_mult_highpart.
762 (expand_highpart_optab): Likewise. Don't clobber target prematurely.
763 (expand_highpart): Evaluate the cost of a shift/add sequence,
764 then see if any of the specialized optabs are cheaper.
766 2004-03-18 Ian Lance Taylor <ian@wasabisystems.com>
768 * mklibgcc.in: Remove obsolete MAYBE_USE_COLLECT2.
770 2004-03-18 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
772 * convert.c (convert_to_real): Add more math builtins.
774 2004-03-18 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
776 * convert.c (convert_to_real): Reformat using switch stmt.
778 2004-03-18 Mark Mitchell <mark@codesourcery.com>
780 * c-common.c (pointer_int_sum): Do not complain about using
781 pointers to pointers-to-members.
783 2004-03-18 Kazu Hirata <kazu@cs.umass.edu>
785 * system.h (MD_ASM_CLOBBERS): Move to "Old target macros that
786 have moved to the target hooks structure".
788 2004-03-18 James E Wilson <wilson@specifixinc.com>
790 * config/mips/mips.md (type): Split move into arith and fmove. Split
791 hilo into mthilo and mfhilo. Add trap. Delete icmp. Fix all uses.
792 * config/mips/5400.md (ir_vr54_hilo, ir_vr54_arith, ir_vr54_fabs):
794 * config/mips/5500.md (ir_vr55_hilo, ir_vr55_arith, ir_vr55_fabs):
796 * config/mips/7000.md (rm7_int_other, rm7_mthilo, rm7_mfhilo,
797 rm7_fp_quick): Likewise.
798 * config/mips/9000.md (rm9k_int, rm9k_mfhilo, rm9k_mthilo,
799 rm9k_fquick): Likewise.
800 * config/mips/sr71k.md (ir_sr70_hilo, ir_sr70_arith, ir_sr70_fabs):
802 (ir_sr70_icmp): Delete.
804 2004-03-18 Richard Kenner <kenner@vlsi1.ultra.nyu.edu>
806 * tree.h (TREE_CHECK2, TREE_CHECK3, TREE_CHECK5): New macros.
807 (tree_check2_failed, tree_check3_failed, tree_check5_failed): New decl.
808 (FUNC_OR_METHOD_CHECK, SET_ARRAY_OR_VECTOR_CHECK): New macros.
809 (REC_OR_UNION_CHECK, NUMERICAL_TYPE_CHECK): Likewise.
810 (TYPE_VALUES, TYPE_DOMAIN, TYPE_FIELDS, TYPE_METHODS, TYPE_VFIELD):
811 Protect with proper check.
812 (TYPE_ARG_TYPES, TYPE_METHOD_BASETYPE, TYPE_OFFSET_BASETYPE): Likewise.
813 (TYPE_MIN_VALUE, TYPE_MAX_VALUE): Likewise.
814 * tree.c (type_hash_eq): Rewrite to access proper fields for each type.
815 (tree_check2_failed, tree_check3_failed, tree_check5_failed): New.
816 * c-typeck.c (build_array_ref): Use TYPE_DOMAIN, not TYPE_VALUES.
817 * dwarf2out.c (gen_enumeration_type_die): Use TYPE_VALUES,
819 * stor-layout.c (set_sizetype): Use TYPE_ORIG_SIZE_TYPE.
821 2004-03-18 Mostafa Hagog <mustafa@il.ibm.com>
823 * gcse.c (eliminate_partially_redundant_loads): Reject change if
824 dest is set between beginning and current insn.
826 2004-03-18 Mark Mitchell <mark@codesourcery.com>
828 * c-decl.c (grokdeclarator): Do not complain about redeclaring
829 visible "static" identifiers "extern" in a local scope.
830 * dwarf2out.c (loc_descriptor_from_tree): Handle pre- and
831 post-increments/decrements.
833 2004-03-18 Bob Wilson <bob.wilson@acm.org>
835 * config/xtensa/xtensa.c (current_function_arg_words): Delete.
836 (xtensa_builtin_saveregs): Use current_function_args_info.arg_words.
837 (xtensa_va_start): Remove assignment to current_function_arg_words.
839 2004-03-18 Richard Sandiford <rsandifo@redhat.com>
841 * alias.c (record_set): Detect the case where a register is assigned
842 a new value that has the same base term as the old one.
844 2004-03-18 Zdenek Dvorak <rakdver@atrey.karlin.mff.cuni.cz>
847 * loop-doloop.c: New file.
848 * Makefile.in (doloop.o): Remove.
849 (loop-doloop.o): New.
850 * cfgloop.h (get_loop_level, doloop_optimize_loops): Declare.
851 * cfgloopanal.c (get_loop_level): New function.
852 * loop-iv.c (iv_number_of_iterations): Handle case when loop
853 is leaved immediatelly.
854 * loop.c (strength_reduce): Do not call doloop optimization.
855 * loop.h (LOOP_BCT): Removed.
856 * passes.c (rest_of_handle_loop_optimize): Do not use LOOP_BCT.
857 (rest_of_handle_loop2): Call doloop_optimize_loops.
858 (rest_of_compilation): Test for optimizations moved to
859 rest_of_handle_loop2.
861 2004-03-17 Fariborz Jahanian <fjahanian@apple.com>
863 * config/rs6000/rs6000.c (rs6000_stack_info): correct reg_size
865 (rs6000_emit_prologue): Ditto.
866 (rs6000_emit_epilogue): Ditto.
867 * config/rs6000/rs6000.h: Definition of DWARF_CIE_DATA_ALIGNMENT
868 macro for mixed mode.
870 2004-03-18 Jan Hubicka <jh@suse.cz>
872 * predict.c (propagate_freq): Compute correctly frequency of
875 2004-03-17 Eric Christopher <echristo@redhat.com>
877 * builtins.c (apply_args_size): Use reg_raw_mode.
878 (apply_result_size): Ditto.
880 2004-03-17 Ralf Corsepius <corsepiu@faw.uni-ulm.de>
883 * config/rtems.h: Add STD_LIB_SPEC and LIB_SPEC.
885 2004-03-17 Jakub Jelinek <jakub@redhat.com>
887 * config/rs6000/t-linux64 (bispecs): Don't add -mlong-double-128 for
888 32-bit builds when defaulting to 32-bit.
890 2004-03-17 Jan Hubicka <jh@suse.cz>
892 * cfgrtl.c (rtl_create_basic_block): Pre-allocate basic_block_info
895 2004-03-17 James E Wilson <wilson@specifixinc.com>
897 * config/mips/mips.md (zero_extendsidi2): Add length attribute.
898 (hazard_nop): Change type to nop.
899 (type): Split arith into arith, shift, slt, clz. Delete darith.
900 Fix all uses. Change arith to multi if more than one insn emitted.
901 * config/mips/5400.md (ir_vr54_arith): Likewise.
902 * config/mips/5500.md (ir_vr55_arith): Likewise.
903 * config/mips/7000.md (rm7_int_other): Likewise.
904 * config/mips/9000.md (rm9k_int): Likewise.
905 * config/mips/sr71k.md (ir_sr70_arith): Likewise.
907 2004-03-17 Joel Brobecker <brobecker@gnat.com>
909 * dwarf2out.c (subrange_type_die): Define new variable "subtype"
910 to hold the subtype tree instead of recomputing it several times.
912 2004-03-17 Kazu Hirata <kazu@cs.umass.edu>
914 * config/mn10300/mn10300.c (notice_update_cc): Don't handle
916 * config/mn10300/mn10300.md (cc): Remove "invert".
918 2004-03-16 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
920 * builtins.c (integer_valued_real_p): Add builtin rint.
921 (fold_builtin): Likewise.
922 * convert.c (convert_to_real): Likewise.
924 * convert.c (convert_to_real): Fix typos in `long double'
927 2004-03-16 Mark Mitchell <mark@codesourcery.com>
930 * fold-const.c (fold): Set TREE_NO_UNUSED_WARNING on implicitly
931 generated COMPOUND_EXPRs.
933 2004-03-16 Ralf Corsepius <corsepiu@faw.uni-ulm.de>
935 * config/h8300/t-rtems (h8300-*-rtems*): New.
937 2004-03-16 Eric Christopher <echristo@redhat.com>
939 * doc/cppopts.texi(fwide-exec-charset): Fix typo.
941 2004-03-16 Kazu Hirata <kazu@cs.umass.edu>
943 * config/i386/i386-protos.h: Add a prototype for
944 ix86_reverse_condition.
945 * config/i386/i386.c (ix86_reverse_condition): New.
946 * config/i386/i386.h (REVERSE_CONDITION): Use
947 ix86_reverse_condition.
948 * config/i386/i386.md: Use ix86_reverse_condition instead of
951 2004-03-16 J. Brobecker <brobecker@gnat.com>
953 * dwarf2out.c (loc_descriptor_from_tree): Add handling for MIN_EXPR.
955 2004-03-16 Nathanael Nerode <neroden@gcc.gnu.org>
958 * Makefile.in: Pass $(INCLUDES) down to libgcc.mk explicitly.
960 2004-03-16 Paolo Bonzini <bonzini@gnu.org>
962 * c-common.c (c_common_type_for_mode): Build vector types on
964 (handle_mode_attribute): Deprecate using the mode attribute
965 to create vector types. Fix indentation.
966 (vector_type_node_list): Remove.
967 (handle_vector_size_attribute): Create vector types on demand.
968 Strip a NON_LVALUE_EXPR from the attribute if there is one.
969 * c-typeck.c (comptypes): Make vector types compatible if they
970 have the same underlying mode.
971 (convert_for_assignment): Use comptypes to convert between
973 * tree.c (build_common_tree_nodes_2): Do not create vector types.
974 * config/arm/arm.c (arm_init_iwmmxt_builtins): Create necessary
976 * tree.h: Remove vector types.
977 * config/i386/i386.c (i386_init_mmx_sse_builtins): Likewise.
978 * config/rs6000/rs6000.c (rs6000_init_builtins): Likewise.
979 (V16QI_type_node, V2SI_type_node, V2SF_type_node, V4HI_type_node,
980 V4SI_type_node, V4SF_type_node, V8HI_type_node): New globals.
981 * doc/extend.texi (Vector Types): Document how to use the
982 vector_size attribute to create vectors, rather than mode.
984 * config/arm/mmintrin.h: Use vector_size attribute, not mode.
985 * config/i386/emmintrin.h: Likewise.
986 * config/i386/mmintrin.h: Likewise.
987 * config/i386/xmmintrin.h: Likewise.
988 * config/sh/ushmedia.h: Likewise.
990 2004-03-16 Kazu Hirata <kazu@cs.umass.edu>
992 * config/freebsd-spec.h, config/arc/arc-protos.h,
993 config/arm/aout.h, config/arm/elf.h, config/arm/freebsd.h,
994 config/arm/linux-gas.h, config/arm/semi.h,
995 config/cris/cris-protos.h, config/i386/xm-djgpp.h,
996 config/ia64/freebsd.h, config/mips/7000.md,
997 config/mips/9000.md, config/ns32k/ns32k-protos.h,
998 config/sparc/pbd.h: Update copyright.
1000 2004-03-16 Ralf Corsepius <corsepiu@faw.uni-ulm.de>
1003 * config.gcc: Switch sh-*-rtems* to ELF. Add sh-*-rtemscoff.
1005 2004-03-16 Paolo Bonzini <bonzini@gnu.org>
1007 * combine.c (combine_simplify_rtx): Remove the "last"
1008 parameter and its documentation. Adjust recursive calls.
1009 (simplify_logical): Always perform the only simplification
1010 controlled by "last", if the simplified expression is
1012 (try_combine): Do not pass the "last" parameter to
1013 combine_simplify_rtx.
1015 2004-03-16 Richard Sandiford <rsandifo@redhat.com>
1018 * config/mips/mips.md (UNSPEC_GP): New constant.
1019 * config/mips/mips.c (CONST_GP_P): Expect the CONST to contain
1020 an UNSPEC instead of (reg $gp).
1021 (mips16_gp_pseudo_reg): Change accordingly.
1022 (print_operand): Print $gp directly when handling CONST_GP_P.
1024 2004-03-16 Richard Zidlicky <rz@linux-m68k.org>
1026 * config.gcc, config/m68k/linux.h: Implement with-cpu for m68k-linux.
1027 * longlong.h: Make code 68060 clean when compiling for m68060.
1029 2004-03-16 Richard Zidlicky <rz@linux-m68k.org>
1031 * config/m68k/m68k.md: Fix constraints for bitfield instructions.
1032 * doc/md.texi: Clarify description of "i" constraint.
1034 2004-03-15 James E Wilson <wilson@specifixinc.com>
1036 * config/mips/mips.md (type): Split load into load, fpload, fpidxload.
1037 Split store into store, fpstore, fpidxstore. Fix all uses.
1038 * config/mips/5400.md (ir_vr54_load, ir_vr54_store, ir_vr54_fstore):
1040 * config/mips/5500.md (ir_vr55_load, i5_vr55_store): Likewise.
1041 * config/mips/7000.md (rm7_ld, rm7_st): Likewise.
1042 * config/mips/9000.md (rm9k_load, rm9k_store): Likewise.
1043 * config/mips/sr71k.md (ir_sr70_load, ir_sr70_store, ir_sr70_fload,
1044 ir_sr70_fstore): Likewise.
1046 2004-03-15 Richard Henderson <rth@redhat.com>
1049 * except.c (collect_one_action_chain): Record action for cleanup
1050 outer of exception spec.
1052 2004-03-15 Ian Lance Taylor <ian@wasabisystems.com>
1054 * config/rs6000/host-darwin.c (darwin_rs6000_gt_pch_use_address):
1055 Fix the check for abort and only do the mmap if we can.
1057 2004-03-15 Eric Botcazou <ebotcazou@act-europe.fr>
1059 * config/sparc/sparc.h: Rework comments about the code model
1060 in 64-bit environment and the mode 'Pmode'.
1061 * doc/invoke.texi (SPARC options): Rework description of the
1062 different code models supported in 64-bit environment.
1064 2004-03-15 Kazu Hirata <kazu@cs.umass.edu>
1066 * defaults.h (REVERSIBLE_CC_MODE): Define.
1067 * jump.c (reversed_comparison_code_parts): Don't check if
1068 REVERSIBLE_CC_MODE is defined.
1070 2004-03-15 Kazu Hirata <kazu@cs.umass.edu>
1072 * c-incpath.c, c-incpath.h, c-pch.c, c.opt, cppexp.c,
1073 et-forest.h, genattr.c, ggc-none.c, hosthooks-def.h,
1074 hosthooks.h, params.h, ra-colorize.c, web.c,
1075 config/darwin-c.c, config/alpha/freebsd.h, config/arm/pe.c,
1076 config/avr/avr-protos.h, config/avr/avr.md,
1077 config/fr30/fr30-protos.h, config/fr30/fr30.md,
1078 config/h8300/fixunssfsi.c, config/i386/darwin.h,
1079 config/i386/freebsd.h, config/i386/freebsd64.h,
1080 config/ia64/hpux.h, config/ia64/unwind-ia64.c,
1081 config/ip2k/libgcc.S, config/m32r/xm-m32r.h,
1082 config/mmix/mmix-modes.def, config/ns32k/netbsd.h,
1083 config/ns32k/ns32k.md, config/pa/pa64-hpux.h,
1084 config/pa/pa64-regs.h, config/rs6000/aix41.h,
1085 config/rs6000/aix43.h, config/rs6000/host-darwin.c,
1086 config/sparc/aout.h, config/sparc/freebsd.h,
1087 config/sparc/litecoff.h, config/vax/vax-protos.h,
1088 doc/hostconfig.texi, doc/include/gcc-common.texi: Update
1091 2004-03-15 Paul Brook <paul@codesourcery.com>
1093 * config/arm/arm.c (thumb_expand_prologue): Tie prologue insns to fp.
1095 2004-03-15 Gabriel Dos Reis <gdr@integrable-solutions.net>
1097 * c-pretty-print.c (pp_c_semicolon): Fix formatting.
1098 (pp_c_cv_qualifier): Document.
1099 (pp_c_space_for_pointer_operator): Likewise.
1100 (pp_c_integer_constant): Likewise.
1101 (pp_c_identifier): Likewise.
1102 (pp_c_init_declarator): Don't print function body.
1104 2004-03-14 Joseph S. Myers <jsm@polyomino.org.uk>
1106 * doc/contrib.texi, doc/extend.texi, doc/gcov.texi,
1107 doc/install.texi, doc/invoke.texi, doc/makefile.texi,
1108 doc/sourcebuild.texi, doc/tm.texi, doc/trouble.texi: Capitalize
1109 "gcc", "g++" and "g77" or mark up with appropriate markup. Adjust
1110 wording and grammar.
1112 2004-03-14 Roger Sayle <roger@eyesopen.com>
1114 * alias.c (get_alias_set): Replace calls via (*lang_hooks.foo) ()
1115 with lang_hooks.foo ().
1116 * builtins.c (expand_builtin_va_arg): Likewise.
1117 * c-common.c (fname_as_string, c_common_truthvalue_conversion,
1118 c_common_type_for_mode, c_common_nodes_and_builtins,
1119 handle_mode_attribute, handle_vector_size_attribute): Likewise.
1120 * c-convert.c (convert): Likewise.
1121 * c-format.c (check_format_types): Likewise.
1122 * c-objc-common.c (c_tree_printer): Likewise.
1123 * c-typeck.c (build_unary_op, build_conditional_expr,
1124 build_binary_op): Likewise.
1125 * calls.c (try_to_integrate, expand_call,
1126 emit_library_call_value_1): Likewise.
1127 * cgraph.c (cgraph_node_name, cgraph_function_possibly_inlined_p):
1129 * cgraphunit.c (record_call_1, cgraph_analyze_function,
1130 cgraph_expand_function): Likewise.
1131 * convert.c (convert_to_pointer, convert_to_integer): Likewise.
1132 * coverage.c (build_fn_info_type, build_ctr_info_type,
1133 build_gcov_info, create_coverage): Likewise.
1134 * dbxout.c (dbxout_init): Likewise.
1135 * diagnostic.c (diagnostic_report_current_function): Likewise.
1136 * dojump.c (do_jump): Likewise.
1137 * dwarf2out.c (dwarf2_name): Likewise.
1138 * except.c (init_eh): Likewise.
1139 * explow.c (expr_size, int_expr_size): Likewise.
1140 * expmed.c (make_tree, const_mult_add_overflow_p, expand_mult_add):
1142 * expr.c (store_expr, store_constructor, safe_from_p,
1143 expand_expr_real, do_store_flag, try_casesi): Likewise.
1144 * function.c (push_function_context_to, pop_function_context_from,
1145 free_after_parsing, assign_stack_local_1, assign_stack_temp_for_type,
1146 put_var_into_stack, allocate_struct_function, current_function_name):
1148 * integrate.c (copy_decl_for_inlining, expand_inline_function):
1150 * langhooks.c (lhd_clear_binding_stack, write_global_declarations,
1151 lhd_print_error_function): Likewise.
1152 * opts.c (handle_option, decode_options): Likewise.
1153 * passes.c (open_dump_file): Likewise.
1154 * print-tree.c (print_node): Likewise.
1155 * stmt.c (expand_fixup, fixup_gotos, expand_asm_operands,
1156 expand_decl_cleanup, emit_case_nodes): Likewise.
1157 * stor-layout.c (variable_size): Likewise.
1158 * toplev.c (announce_function, wrapup_global_declarations,
1159 check_global_declarations, compile_file, default_tree_printer,
1160 process_options, lang_dependent_init, finalize): Likewise.
1161 * tree-dump.c (dequeue_and_dump): Likewise.
1162 * tree-inline.c (remap_decl, remap_block, copy_body_r,
1163 initialize_inlined_parameters, declare_return_variable,
1164 inlinable_function_p, expand_call_inline, optimize_inline_calls,
1165 walk_tree, copy_tree_r): Likewise.
1166 * tree-optimize.c (tree_rest_of_compilation): Likewise.
1167 * tree.c (decl_assembler_name, tree_size, size_in_bytes, staticp,
1168 unsafe_for_reeval, get_unwidened, get_narrower, get_callee_fndecl,
1169 variably_modified_type_p, dump_tree_statistics): Likewise.
1170 * varasm.c (assemble_variable, compare_constant, copy_constant,
1171 force_const_mem, compute_reloc_for_constant, output_constant,
1172 output_addressed_constants, initializer_constant_valid_p): Likewise.
1174 2004-03-14 Kelley Cook <kcook@gcc.gnu.org>
1176 * doc/install.texi: Make autoconf 2.13 the exception, not the rule.
1178 2004-03-14 Andreas Tobler <a.tobler@schweiz.ch>
1180 * doc/install.texi: Reflect autoconf and automake version for
1181 libffi. Update autoconf version to 2.59.
1183 2004-03-13 Roger Sayle <roger@eyesopen.com>
1185 * fold-const.c (negate_expr, operand_equal_for_comparison_p,
1186 optimize_bit_field_compare, decode_field_reference, all_ones_mask_p,
1187 make_range, build_range_check, fold_range_test, unextend,
1188 constant_boolean_node, fold_binary_op_with_conditional_arg,
1189 fold_truthop, fold_mathfn_compare, fold_inf_compare,
1190 fold_single_bit_test, fold): Replace calls via (*lang_hooks.foo) ()
1191 with lang_hooks.foo ().
1193 2004-03-14 Richard Earnshaw <rearnsha@arm.com>
1195 * arm.h (EXTRA_CONSTRAINT_STR_ARM): Update comment.
1197 2004-03-13 Dara Hazeghi <dhazeghi@yahoo.com>
1199 * doc/install.texi: Note status of -fnew-ra.
1201 2004-03-13 Eric Botcazou <ebotcazou@libertysurf.fr>
1204 * expr.c (store_expr): Call emit_queue before generating the move
1205 from the temporary to the original target. Protect the temporary
1208 2004-03-13 Jakub Jelinek <jakub@redhat.com>
1211 * config/s390/s390.c (legitimize_pic_address): Don't abort on UNSPEC
1212 other than UNSPEC_GOTOFF.
1214 2004-03-13 Richard Earnshaw <rearnsha@arm.com>
1216 * arm.c (arm_legitimate_address_p): New argument, OUTER. Pass through
1217 to arm_legitimate_index_p. Update all callers with SET as default
1219 (arm_legitimate_index_p): New argument, OUTER. Restrict the index
1220 range if OUTER is a sign-extend operation on QImode. Correctly
1221 reject shift operations on sign-extended QImode addresses.
1222 (bad_signed_byte_operand): Delete.
1223 (arm_extendqisi_mem_op): New function.
1224 * arm.h (EXTRA_CONSTRAINT_ARM): Delete. Replace with...
1225 (EXTRA_CONSTRAINT_STR_ARM): ... this. Handle extended address
1227 (CONSTRAINT_LEN): New.
1228 (EXTRA_CONSTRAINT): Delete. Replace with...
1229 (EXTRA_CONSTRAINT_STR): ... this.
1230 (PREDICATE_CODES): Remove bad_signed_byte_operand.
1231 * arm.md (extendqihi_insn): Use new constraint Uq. Rework. Length
1232 is now always default.
1233 (define_splits for bad sign-extend loads): Delete.
1234 (arm_extendqisi, arm_extendqisi_v5): Likewise.
1235 * arm/vfp.md (arm_movsi_vfp, arm_movdi_vfp, movsf_vfp, movdf_vfp):
1236 Rework 'U' constraint to 'Uv'.
1237 * arm-protos.h: Remove bad_signed_byte_operand. Add
1238 arm_extendqisi_mem_op.
1239 * doc/md.texi (ARM constraints): Rename VFP constraint (now Uv).
1242 2004-03-13 Alan Modra <amodra@bigpond.net.au>
1244 * config/rs6000/rs6000.c (rs6000_va_arg): Replace SPLIT_COMPLEX_ARGS
1245 with targetm version.
1248 * config/rs6000/rs6000.h (UNITS_PER_ARG, RS6000_ARG_SIZE): Delete.
1249 (HARD_REGNO_MODE_OK): Disallow TFmode for fp31.
1250 * config/rs6000/rs6000.c (rs6000_arg_size): New function.
1251 Update all users of RS6000_ARG_SIZE.
1252 (function_arg_advance): Count fregno using mode size.
1253 (function_arg): Handle long double split over regs and memory.
1254 (function_arg_partial_nregs): Likewise.
1255 (rs6000_va_arg): Repackage complex args.
1257 2004-03-13 Dean Ferreyra <dferreyra@igc.org>
1260 * config/avr/avr.c (avr_progmem_p): Add "attributes" parameter.
1261 (avr_insert_attributes): Pass "attributes" to avr_progmem_p.
1262 * config/avr/avr-protos.h (avr_progmem_p): Change prototype.
1264 2004-03-12 Jakub Jelinek <jakub@redhat.com>
1266 * config/rs6000/rs6000-protos.h (rs6000_output_dwarf_dtprel): Add
1268 * config/rs6000/rs6000.c (rs6000_output_dwarf_dtprel): New.
1269 * config/rs6000/rs6000.h (ASM_OUTPUT_DWARF_DTPREL): Define.
1271 2003-03-12 Andrew Pinski <apinski@apple.com>
1273 * config/rs6000/host-darwin.c (darwin_rs6000_gt_pch_use_address):
1274 Use ret instead of result. Use addr instead of base.
1276 2004-03-12 David Edelsohn <edelsohn@gnu.org>
1278 * doc/install.texi (*-ibm-aix*): Document assembler and achiver
1279 fixes required by libstdc++ and update installation instructions
1282 2004-03-12 Danny Smith <dannysmith@users.sourceforge.net>
1284 * config/i386/winnt.c (i386_pe_strip_name_encoding_full): Strip
1285 leading '@' on fastcall symbols before stripping suffix.
1287 2004-03-12 Roger Sayle <roger@eyesopen.com>
1289 * combine.c (unmentioned_reg_p): New function to check whether an
1290 expression is a "specialization" of another, i.e. that there are
1291 no registers or memory references mentioned in the first that don't
1292 appear in the second.
1293 (unmentioned_reg_p_1): New helper subroutine of unmentioned_reg_p.
1294 (combine_instructions): Also try combining instructions using the
1295 REG_EQUAL note from a preceding log-linked instruction.
1297 2004-03-12 Roger Sayle <roger@eyesopen.com>
1299 * config/i386/i386.c (ix86_split_ashrdi): Optimize shift by 63.
1301 2004-03-12 Matt Austern <austern@apple.com>
1303 * target.h (struct gcc_target): New target hook, unwind_label.
1304 * target-def.h (TARGET_ASM_EMIT_UNWIND_LABEL): New hook.
1305 * output.h (default_emit_unwind_label): New function.
1306 * default.h (TARGET_EXPLICIT_INSTANTIATIONS_ONE_ONLY): New macro.
1307 (TARGET_USES_WEAK_UNWIND_INFO): New target macro.
1308 (TARGET_SUPPORTS_HIDDEN): New target macro.
1309 * dwarf2out.c (struct dw_fde_struct): Add field for function decl
1310 that corresponds to this FDE.
1311 (FRAME_BEGIN_LABEL): Allow target to override default label.
1312 (output_call_frame_info): If FDEs are linknonce, then use extra
1313 indirection for FDE encoding, output a label for each FDE, and
1314 output an empty label for each function without an FDE.
1315 (dwarf2out_begin_prologue): Set up decl field when creating an FDE.
1316 * varasm.c (globalize_decl): Call ASM_MAKE_LABEL_LINKONCE for
1317 decls with DECL_ONE_ONLY set, if that macro is defined.
1318 (make_decl_one_only): Don't use DECL_COMMON if we're compiling
1319 for a SUPPORTS_ONE_ONLY target.
1320 * config/darwin-protos.h (darwin_unique_section): Declare.
1321 (darwin_asm_named_section): Likewise.
1322 (darwin_section_type_flags): Likewise.
1323 (darwin_non_lazy_pcrel): Likewise.
1324 (darwin_emit_unwind_label): Likewise.
1325 (darwin_make_decl_one_only): Likewise.
1326 * config/darwin.c (machopic_finish): Get rid of tweak that
1327 eliminate stubs for symbols that are defined.
1328 (darwin_encode_section_info): Don't treat weak functions as defined.
1329 (darwin_make_decl_one_only): Define.
1330 (darwin_asm_named_section): Likewise.
1331 (darwin_section_type_flags): Likewise.
1332 (darwin_unique_section): Likewise.
1333 (darwin_emit_unwind_label): Likewise.
1334 (darwin_non_lazy_pcrel): Likewise.
1335 (darwin_asm_output_dwarf_delta): Difference between two labels is
1336 local only if both labels are local.
1337 * config/darwin.h (MAKE_DECL_ONE_ONLY): Define.
1338 (ASM_MAKE_LABEL_LINKONCE): Likewise.
1339 (TARGET_SUPPORTS_HIDDEN): Likewise.
1340 (TARGET_USES_WEAK_UNWIND_INFO): Likewise.
1341 (TARGET_EXPLICIT_INSTANTIATIONS_ONE_ONLY): Likewise.
1342 (FRAME_BEGIN_LABEL): Likewise.
1343 (ASM_DECLARE_OBJECT_NAME): Make references to weak symbols indirect.
1344 (ASM_DECLARE_FUNCTION_NAME): Likewise.
1345 (darwin_eh_frame_section): Give __eh_frame section the coalesced flag.
1346 (TARGET_ASM_UNIQUE_SECTION): Define.
1347 (EH_FRAME_SECTION_NAME): Define.
1348 (EH_FRAME_SECTION_ATTR): Likewise.
1349 (ASM_MAYBE_OUTPUT_ENCODED_ADDR_RTX): Likewise.
1350 (TARGET_ASM_NAMED_SECTION): Likewise.
1351 (TARGET_SECTION_TYPE_FLAGS): Likewise.
1352 * doc/tm.texi: Document TARGET_USES_WEAK_UNWIND_INFO,
1353 TARGET_EXPLICIT_INSTANTIATIONS_ONE_ONLY, TARGET_SUPPORTS_HIDDEN,
1354 TARGET_ASM_EMIT_UNWIND_LABEL.
1356 2004-03-12 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
1358 * builtins.c (expand_builtin_mathfn): Add pow10* to the
1359 existing exp10* case.
1360 (expand_builtin): Likewise.
1362 2004-03-12 Eric Botcazou <ebotcazou@libertysurf.fr>
1364 * doc/tm.texi (registers) <Values in Registers>: Add
1365 entry for REGMODE_NATURAL_SIZE.
1367 2004-03-12 Richard Henderson <rth@redhat.com>
1370 * target.h (struct gcc_target): Move calls substructure before
1371 booleans. Add split_complex_arg.
1372 * function.c (assign_parms, split_complex_args): Use it.
1373 * calls.c (expand_call): Likewise.
1374 (split_complex_values): Likewise. Check for splittable types
1375 before allocating memory.
1376 (split_complex_types): Likewise.
1377 * system.h (SPLIT_COMPLEX_ARGS): Poison.
1378 * expr.h (SPLIT_COMPLEX_ARGS): Remove.
1379 * target-def.h (TARGET_SPLIT_COMPLEX_ARG): New.
1380 * config/alpha/alpha.c (alpha_split_complex_arg): New.
1381 (TARGET_SPLIT_COMPLEX_ARG): New.
1382 * config/alpha/alpha.h (SPLIT_COMPLEX_ARGS): Remove.
1383 * config/rs6000/rs6000.c (TARGET_SPLIT_COMPLEX_ARG): New.
1384 (rs6000_override_options): Zap it for non-AIX.
1385 (rs6000_function_value): Use targetm.calls.split_complex_arg.
1386 * config/rs6000/rs6000.h (SPLIT_COMPLEX_ARGS): Remove.
1387 * config/xtensa/xtensa.c (TARGET_SPLIT_COMPLEX_ARG): New.
1388 * config/xtensa/xtensa.h (SPLIT_COMPLEX_ARGS): Remove.
1389 * doc/tm.texi (TARGET_SPLIT_COMPLEX_ARG): Modify from old
1390 SPLIT_COMPLEX_ARGS entry.
1392 2004-03-11 Richard Henderson <rth@redhat.com>
1394 * config/alpha/alpha.c (xfloating_ops, vax_cvt_ops): New.
1395 (alpha_lookup_xfloating_lib_func): Use them, return rtx.
1396 (alpha_emit_xfloating_arith): Update to match.
1397 (alpha_emit_xfloating_compare): Likewise.
1398 (alpha_emit_xfloating_cvt): Likewise.
1399 (alpha_emit_xfloating_libcall): Take already built symbol,
1401 * config/alpha/alpha.md (extendsftf2, extenddftf2): Take
1404 2004-03-11 Richard Henderson <rth@redhat.com>
1407 * config/alpha/alpha.h (STACK_BOUNDARY): Set to 128.
1409 * simplify-rtx.c (simplify_relational_operation): Fix typo.
1411 2004-03-11 Richard Henderson <rth@redhat.com>
1414 * except.c (remove_unreachable_regions): Look thru CALL_PLACEHOLDER.
1416 2004-03-11 Ulrich Weigand <uweigand@de.ibm.com>
1419 * calls.c (load_register_parameters): If BLOCK_REG_PADDING is not
1420 defined, pass small BLKmode values in registers in the low-order part.
1422 2004-03-11 Ulrich Weigand <uweigand@de.ibm.com>
1424 * combine.c (if_then_else_cond): Check for NULL return value of
1425 simplify_gen_subreg.
1427 2004-03-11 Richard Sandiford <rsandifo@redhat.com>
1430 * config/mips/mips.h (UNITS_PER_FPVALUE): Fix value for
1431 TARGET_SINGLE_FLOAT.
1433 2004-03-11 Steve Ellcey <sje@cup.hp.com>
1435 * config/ia64/hpux.h (TARGET_INIT_LIBFUNCS): Add undef.
1436 * config/ia64/ia64.h (TARGET_INIT_LIBFUNCS): Add define.
1437 * config/ia64/ia64.c (ia64_init_libfuncs): New.
1438 (ia64_hpux_init_libfuncs): Add call to ia64_init_libfuncs.
1440 2004-03-11 Roger Sayle <roger@eyesopen.com>
1442 * fold-const.c (negate_expr_p) <RSHIFT_EXPR>: We can optimize
1443 -((int)X>>C) where C is an integer constant one bit less than the
1444 size of X into (unsigned)X>>C. Similarly for unsigned->signed.
1445 (negate_expr) <RSHIFT_EXPR>: Implement the above transformations.
1447 * simplify-rtx.c (simplify_unary_operation): Also implement the
1448 above transformations at the RTL level.
1450 2004-03-11 Alan Modra <amodra@bigpond.net.au>
1452 * real.c (encode_ibm_extended): Do round low word.
1454 2004-03-11 Ben Elliston <bje@wasabisystems.com>
1456 * config/arm/arm.md (is_xscale): Comment this attribute and move
1457 it a bit further up in the file, closer to related attributes.
1459 2004-03-11 Eric Botcazou <ebotcazou@libertysurf.fr>
1461 * config/host-solaris.c (sol_gt_pch_use_address): Add
1462 missing terminating marker to comment.
1464 2004-03-11 Richard Sandiford <rsandifo@redhat.com>
1466 * config/mips/mips.md: Use move_operand in splitters for 64-bit moves.
1467 (movdi, movsi, movhi, movqi, movsf, movdf): Remove predicates.
1468 (*movdi_32bit_mips16, *movsi_mips16, *movhi_mips16, *movqi_mips16)
1469 (*movsf_mips16, *movdf_mips16): Name unnamed patterns. Use
1470 move_operand as source predicate in all cases.
1471 (*movdi_32bit): Renamed from movdi_internal. Remove 'F' constraint.
1472 Test reg_or_0_operand. Use move_operand as source predicate.
1473 (*movdi_64bit): Renamed from movdi_internal2. Test reg_or_0_operand.
1474 (*movdi_64bit_mips16): Renamed from movdi_internal2_mips16.
1475 (*movsi_internal): Renamed from movsi_internal. Test reg_or_0_operand.
1476 (movhi, movqi, movsf, movdf): Use mips_legitimize_move.
1477 (*movhi_internal): Renamed from movhi_internal. Test reg_or_0_operand.
1478 Use move_operand as source predicate. Remove 'K' constraint.
1479 (*movqi_internal): Likewise movqi_internal.
1480 (*movsf_hardfloat): Renamed from movsf_internal1. Test
1481 reg_or_0_operand. Use move_operand as source predicate.
1482 (*movsf_softfloat): Likewise movsf_internal2.
1483 (*movdf_hardfloat_64bit): Likewise movsf_internal1a.
1484 (*movdf_hardfloat_32bit): Likewise movsf_internal1b.
1485 (*movdf_softfloat): Likewise movdf_internal2.
1486 * config/mips/mips.c (move_operand): Match arbitrary CONST_INTs
1487 for DImode if !TARGET_64BIT.
1488 (mips_legitimize_move): Simplify accordingly.
1490 2004-03-11 Josef Zlomek <zlomekj@suse.cz>
1493 * var-tracking.c (struct variable_def): Added field refcount.
1494 (variable_htab_free): Decrease the refcount and delete variable
1495 only if there are no more references.
1496 (unshare_variable): New function.
1497 (vars_copy_1): Increase refcount instead of copying the variable.
1498 (variable_union): Share the variables where possible, unshare
1499 the variables if needed.
1500 (variable_different_p): Return false if var1 and var2 are
1502 (variable_was_changed): Init the refcount of new variable.
1503 (set_frame_base_location): Unshare variable if needed.
1504 (set_variable_part): Init the refcount of new variable.
1505 Unshare the variables if needed.
1506 (delete_variable_part): Unshare the variables if needed.
1507 (emit_notes_for_differences_1): Init the refcount of new variable.
1508 (vt_add_function_parameters): Do not add function parameters to
1509 IN set of ENTRY_BLOCK_PTR because it is unused anyway.
1510 (vt_initialize): Do not add frame_base_decl to IN set of
1511 ENTRY_BLOCK_PTR because it is unused anyway.
1513 2004-03-11 Josef Zlomek <zlomekj@suse.cz>
1515 * var-tracking.c (vars_copy_1): Cleanup and speedup chain operations.
1516 (vars_copy): Likewise.
1517 (variable_union): Likewise.
1518 (set_variable_part): Likewise.
1519 (delete_variable_part): Likewise.
1521 2004-03-11 Kazu Hirata <kazu@cs.umass.edu>
1523 * c-typeck.c, combine.c, cse.c, dominance.c, et-forest.h,
1524 ggc-page.c, var-tracking.c, config/fp-bit.c, config/c4x/c4x.c,
1525 config/cris/cris.c, config/i386/ppro.md, config/i860/i860.c,
1526 config/i860/i860.h, config/m32r/m32r.h, config/m32r/xm-m32r.h,
1527 config/m68hc11/m68hc11.h, config/m68hc11/m68hc11.md,
1528 config/mips/mips.c, config/mmix/mmix.c, config/ns32k/ns32k.h,
1529 config/pa/pa.c, config/pa/pa32-regs.h, config/pa/pa64-regs.h,
1530 config/pdp11/pdp11.h, config/rs6000/rs6000.c,
1531 config/stormy16/stormy16.c: Fix comment typos and formatting.
1533 2004-03-11 Nathanael Nerode <neroden@gcc.gnu.org>
1535 * configure: Regenerate, since I forgot to while committing Paolo's
1538 2004-03-08 Paolo Bonzini <bonzini@gnu.org>
1541 Move language detection to the top level.
1542 * configure.ac: Remove code to detect languages,
1543 it now lives exclusively in the top level.
1544 * aclocal.m4 (gcc_AC_PROG_GNAT): Moved to the
1545 top level, renamed to ACX_PROG_GNAT.
1547 2004-03-10 Richard Henderson <rth@redhat.com>
1549 * c-pch.c (c_common_no_more_pch): Update for gt_pch_use_address
1551 * config.host (*-*-solaris2*, *-*-linux*): Add out_host_hook_obj
1552 and host_xmake_file fragments.
1553 * ggc-common.c (gt_pch_save): Update for gt_pch_get_address change.
1554 (gt_pch_restore): Similarly for gt_pch_use_address.
1555 (default_gt_pch_get_address): New.
1556 (mmap_gt_pch_get_address): Split out of gt_pch_save.
1557 (default_gt_pch_use_address): Split out of gt_pch_restore.
1558 (mmap_gt_pch_use_address): Likewise.
1559 * hooks.c (hook_voidp_size_t_null): Remove.
1560 (hook_bool_voidp_size_t_false): Remove.
1561 * hooks.h: Likewise.
1562 * hosthooks-def.h (HOST_HOOKS_GT_PCH_GET_ADDRESS): Use one of the
1563 default_ or mmap_ definitions.
1564 (HOST_HOOKS_GT_PCH_USE_ADDRESS): Likewise.
1565 * hosthooks.h (struct host_hooks): Update gt_pch_get_address
1566 and gt_pch_use_address.
1567 * config/host-linux.c, config/host-solaris.c: New files.
1568 * config/x-linux, config/x-solaris: New files.
1569 * config/rs6000/host-darwin.c (darwin_rs6000_gt_pch_get_address):
1570 Update for changed definition.
1571 (darwin_rs6000_gt_pch_use_address): Likewise.
1572 * doc/hostconfig.texi: Update docs.
1574 2004-03-10 Richard Henderson <rth@redhat.com>
1577 * c-decl.c (grokdeclarator): Don't warn for duplicate qualifiers
1578 except for pedantic c90 mode.
1580 2004-03-10 Kelley Cook <kcook@gcc.gnu.org>
1582 * configure.ac: Bump AC_PREREQ to 2.59.
1583 * configure: Regenerate.
1585 2004-03-10 Uros Bizjak <uros@kss-loka.si>
1587 * optabs.h (enum optab_index): Add new OTI_exp10 and OTI_exp2.
1588 (exp10_optab, exp2_optab): Define corresponding macros.
1589 * optabs.c (init_optabs): Initialize exp10_optab and exp2_optab.
1590 * genopinit.c (optabs): Implement exp10_optab and exp2_optab
1591 using exp10?f2 and exp2?f2 patterns.
1592 * builtins.c (expand_builtin_mathfn): Handle BUILT_IN_EXP10{,F,L}
1593 using exp10_optab, and BUILT_IN_EXP2{,F,L} using exp2_optab.
1594 (expand_builtin): Expand BUILT_IN_EXP10{,F,L} and BUILT_IN_EXP2{,F,L}
1595 using expand_builtin_mathfn if flag_unsafe_math_optimizations is set.
1597 * config/i386/i386.md (exp10sf2, exp10df2, exp10xf2, exp2sf2,
1598 exp2df2, exp2xf2): New patterns to implement exp10, exp10f, exp10l,
1599 exp2, exp2f and exp2l built-ins as inline x87 intrinsics.
1601 2004-03-10 Anthony Green <green@redhat.com>
1603 * doc/invoke.texi (ARM Options): Fix -mpfu typo.
1605 2004-03-10 David Edelsohn <edelsohn@gnu.org>
1607 * config/rs6000/aix.h (TARGET_OS_CPP_BUILTINS): Rename to ...
1608 (TARGET_OS_AIX_CPP_BUILTINS): this. Conditionally define
1610 * config/rs6000/aix41.h (TARGET_OS_CPP_BUILTINS): Use
1611 TARGET_OS_AIX_CPP_BUILTINS.
1612 * config/rs6000/aix43.h (TARGET_OS_CPP_BUILTINS): Same.
1613 * config/rs6000/aix51.h (TARGET_OS_CPP_BUILTINS): Same.
1614 * config/rs6000/aix52.h (TARGET_OS_CPP_BUILTINS): Same.
1615 * config/rs6000/rs6000-c.c (rs6000_cpu_cpp_builtins): Revert
1618 2004-03-10 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
1620 * fold-const.c (tree_expr_nonnegative_p): Add more builtin cases.
1622 2004-03-10 David Edelsohn <edelsohn@gnu.org>
1624 * config/rs6000/rs6000-c.c (rs6000_cpu_cpp_builtins): Define
1625 __LONGDOUBLE128 on AIX.
1627 2004-03-10 Andrew Haley <aph@redhat.com>
1629 PR optimization/14381
1630 * function.c (expand_function_end): Emit a blockage insn before
1631 the epilogue when -fnon-call-exceptions is used.
1633 * except.c (expand_start_all_catch): Make comment more accurate.
1635 2004-03-08 Joel Sherrill <joel@oarcorp.com>
1638 * config/rs6000/t-rtems: Add missing file on branch.
1640 2004-03-10 Ulrich Weigand <uweigand@de.ibm.com>
1642 * dbxout.c (dbxout_symbol_location): Do not output references
1643 to optimized-out constant pool symbols.
1645 2004-03-10 Andreas Schwab <schwab@suse.de>
1647 * config/ia64/ia64.md (divsi3, udivsi3): Remove unused variable
1650 2004-03-09 James E Wilson <wilson@specifixinc.com>
1652 * alias.c (alias_sets_might_conflict_p): New.
1653 * c-typeck.c (build_c_cast): Call it if warn_strict_aliasing > 1.
1654 * common.opt (Wstrict-aliasing=): New.
1655 * flags.h (warn_strict_aliasing): Change type to int.
1656 * opts.c (warn_strict_aliasing): Change type to int.
1657 (common_handle_option): Handle OPT_Wstrict_aliasing_.
1658 * tree.h (alias_sets_might_conflict_p): Declare it.
1659 * doc/invoke.tex (-Wstrict-aliasing=2): Document it.
1661 2004-03-10 Roman Zippel <zippel@linux-m68k.org>
1664 * config/m68k/m68k.h (FIXED_REGISTERS): Add arg pointer.
1665 (CALL_USED_REGISTERS): Likewise.
1666 (REG_CLASS_CONTENTS): Likewise.
1667 (REG_ALLOC_ORDER): New.
1668 (REGNO_REG_CLASS): Use regno_reg_class.
1669 * config/m68k/m68k.c: Add regno_reg_class array.
1671 2004-03-09 Steve Ellcey <sje@cup.hp.com>
1673 * config/ia64/ia64.md (divsi3): Fix algorithm.
1675 (setf_exp_xf): Remove '*' from name.
1676 * testsuite/gcc.dg/20040309-1.c: New test.
1678 2004-03-09 Ian Lance Taylor <ian@wasabisystems.com>
1680 * system.h (SUNOS4_SHARED_LIBRARIES): Poison.
1681 * collect2.c: Remove SUNOS4_SHARED_LIBRARIES code.
1682 * config/sparc/aout.h (TARGET_ASM_SELECT_SECTION): Don't define.
1683 * config/sparc/sparc.c (sparc_aout_select_section): Remove.
1684 (sparc_aout_select_rtx_section): Don't check
1685 SUNOS4_SHARED_LIBRARIES.
1686 * config/sparc/sparc.h (SUNOS4_SHARED_LIBRARIES): Don't define.
1688 2004-03-10 Hans-Peter Nilsson <hp@axis.com>
1691 * doc/md.texi (Pattern Ordering, Dependent Patterns)
1692 (Jump Patterns, Looping Patterns): Wrap in separate "@ifset
1695 2004-03-09 Zack Weinberg <zack@codesourcery.com>
1697 * config/ia64/hpux.h (MULTILIB_DEFAULTS): Define.
1698 (LIBGCC_SPEC): Update to match.
1700 2004-03-09 Zack Weinberg <zack@codesourcery.com>
1702 * c-decl.c (last_function_parms, last_function_parm_tags)
1703 (last_function_parm_others, current_function_parms)
1704 (current_function_parm_tags, current_function_parm_others):
1706 (ARG_INFO_PARMS, ARG_INFO_TAGS, ARG_INFO_TYPES, ARG_INFO_OTHERS):
1708 (grokdeclarator): For function definitions, save the arg-info
1709 block from the declarator in DECL_ARGUMENTS.
1710 (grokparms): Do not write to last_function_parm*. Use ARG_INFO_*
1711 macros to operate on arg-info block. Can assume ARG_INFO_PARMS
1712 contains only PARM_DECLs. Improve diagnostics.
1713 (get_parm_info): Use ARG_INFO_* macros. Improve comments and
1714 diagnostics. Disable some expensive checks if not ENABLE_CHECKING.
1715 (store_parm_decls_newstyle): Take the function to operate on,
1716 and an arg-info block, as arguments; don't get anything from
1717 current_function_* globals.
1718 (store_parm_decls_oldstyle): Likewise.
1719 (store_parm_decls): Pass fndecl and its arg-info block down to
1720 store_parm_decls_newstyle/oldstyle. Send functions with empty
1721 argument lists through store_parm_decls_newstyle to reduce
1723 (pushdecl): Comment on the problems with the call to copy_node.
1724 Clear DECL_ARGUMENTS of the old node after copying it, if it
1725 is an arg-info block instead of a chain of decls.
1726 (start_function): Do not manipulate current_function_parm* or
1727 last_function_parm*.
1729 2004-03-09 Roger Sayle <roger@eyesopen.com>
1730 Andrew Pinski <pinskia@physics.uc.edu>
1732 * ifcvt.c (noce_try_sign_mask): New function to transform
1733 "x = (y < 0) ? z : 0" into the equivalent "x = (y >> C) & z".
1734 (noce_process_if_block): Call noce_try_sign_mask.
1736 2004-03-09 Andrew Pinski <apinski@apple.com>
1738 * c-typeck.c (tagged_types_tu_compatible_p):
1741 2004-03-09 Roger Sayle <roger@eyesopen.com>
1743 * simplify-rtx.c (simplify_const_relational_operation): New function
1744 renamed from simplify_relational_operation.
1745 (simplify_relational_operation): Change prototype to accept an
1746 additional mode argument. Call simplify_const_relational_operation.
1747 (simplify_gen_relational): Update simplify_relational_operation call.
1748 (simplify_ternary_operation): Update simplify_relational_operation
1749 subroutine call to use simplify_const_relational_operation instead.
1751 * rtl.h (simplify_const_relational_operation): Prototype here.
1752 (simplify_relational_operation): Add addtional mode argument.
1754 * combine.c (combine_simplify_rtx): Update calls to
1755 simplify_relational_operation.
1756 (simplify_set): Likewise.
1757 (gen_binary): Likewise.
1758 * cse.c (fold_rtx): Likewise.
1759 * dojump.c (compare_from_rtx): Likewise.
1760 (do_compare_rtx_and_jump): Likewise.
1761 * integrate.c (subst_constants): Likewise.
1762 * unroll.c (simplify_cmp_and_jump_insns): Likewise.
1764 2004-03-09 Kazu Hirata <kazu@cs.umass.edu>
1766 * config/m32r/m32r.md: Remove all define_peephole's.
1768 2004-03-09 Alan Modra <amodra@bigpond.net.au>
1770 * config/rs6000/rs6000.md: Remove trailing whitespace.
1772 2004-03-08 Eric Christopher <echristo@redhat.com>
1774 * Makefile.in (site.exp): Add libiconv variable definition.
1776 2004-03-09 Hans-Peter Nilsson <hp@axis.com>
1778 * configure: Regenerate for config/accross.m4 correction.
1780 2004-03-08 Joel Sherrill <joel@oarcorp.com>
1783 * config/rs6000/t-rtems: Add missing file on branch.
1785 2004-03-08 Roger Sayle <roger@eyesopen.com>
1788 * c-typeck.c (c_mark_addressable): A register variable should
1789 be considered global if its not automatic, i.e. TREE_PUBLIC,
1790 TREE_STATIC or DECL_EXTERNAL.
1791 * function.c (put_var_into_stack): Call abort when placing a
1792 hard register into the stack, if x_parm_reg_stack_loc is NULL.
1794 2004-03-08 Ulrich Weigand <uweigand@de.ibm.com>
1796 * config/s390/s390.md ("*extendqidi2_short_displ"): Add CC clobber.
1797 ("*extendqisi2_short_displ"): Likewise.
1799 2004-03-08 Kazu Hirata <kazu@cs.umass.edu>
1801 * config/pdp11/pdp11.c (comparison_operator_index): Remove.
1802 (comp_operator): Likewise.
1803 * config/pdp11/pdp11-protos.h: Remove corresponding
1806 2004-03-08 Eric Botcazou <ebotcazou@act-europe.fr>
1808 * expr.c (highest_pow2_factor_for_type): Rename into
1809 highest_pow2_factor_for_target. Use DECL_ALIGN instead of
1810 TYPE_ALIGN when the target is a COMPONENT_REF.
1811 (expand_assignment): Ajust call to highest_pow2_factor_for_type.
1813 2004-03-08 Alan Modra <amodra@bigpond.net.au>
1815 * config/rs6000/rs6000.c: Formatting fix.
1816 (legitimate_offset_address_p): Correct offset range check.
1818 * config/rs6000/rs6000.c (rs6000_override_options): Don't override
1819 -msoft-float by -mcpu. Consolidate similar code for MASK_MULTIPLE
1822 2004-03-07 Aldy Hernandez <aldyh@redhat.com>
1824 * config/rs6000/rs6000.md (ashrdi3): Do not call ashrdi3_no_power
1826 ("ashrdi3_no_power"): Disable for little endian.
1829 2004-03-07 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
1831 * fold-const.c (tree_expr_nonnegative_p): Reformat checks for
1834 2004-03-08 Hans-Peter Nilsson <hp@axis.com>
1837 * configure.ac (Target-specific assembler checks) <cris-*-*>: New
1838 case, checking for -no-mul-bug-abort option.
1839 * configure, config.in: Regenerate.
1840 * doc/invoke.texi (CRIS Options): Document -mmul-bug-workaround
1841 and -mno-mul-bug-workaround.
1842 * config/cris/cris.md ("smulsi3_highpart", "umulsi3_highpart")
1843 ("mulsidi3", "umulsidi3"): Prefix output template with "%!".
1844 ("umulhisi3", "umulqihi3", "mulsi3", "mulqihi3", "mulhisi3"):
1845 Ditto. Make attribute "slottable" dependent on TARGET_MUL_BUG.
1846 * config/cris/mulsi3.asm (__Mul) [__CRIS_arch_version >= 10]: Make
1847 sure mulu.d is not last on cache-line.
1848 * config/cris/cris.h (ASM_SPEC): Translate -mno-mul-bug-workaround
1849 into -no-mul-bug-abort depending on HAVE_AS_MUL_BUG_ABORT_OPTION.
1850 (TARGET_MASK_MUL_BUG, TARGET_MUL_BUG): New macros.
1851 (TARGET_SWITCHES): New options -mmul-bug-workaround and
1852 -mno-mul-bug-workaround.
1853 (TARGET_DEFAULT): Include TARGET_MASK_MUL_BUG.
1854 (PRINT_OPERAND_PUNCT_VALID_P): Include '!'.
1855 * config/cris/cris.c (cris_operand_extend_operator): Clarify
1856 relation to MULT in head comment.
1857 (cris_op_str): Abort for MULT.
1858 (cris_print_operand) <case '!'>: New case.
1860 2004-03-08 Alan Modra <amodra@bigpond.net.au>
1863 * dwarf2out.c (enum dw_val_class): Rename dw_val_class_float to
1864 dw_val_class_vec. Replace use throughout file.
1865 (dw_float_const): Delete.
1866 (dw_vec_const): New.
1867 (dw_val_struct_union): Rename val_float to val_vec. Replace use
1869 (add_AT_vec): Rename from add_AT_float. Add elt_size param.
1870 (same_dw_val_p): Adjust vec comparison. Use memcmp.
1871 (size_of_die): Adjust dw_val_class_vec sizing.
1872 (output_die): Output dw_val_class_vec.
1873 (insert_int, extract_int, insert_float): New functions.
1874 (add_const_value_attribute): Use insert_float for CONST_DOUBLE.
1875 Handle CONST_VECTOR.
1876 (add_location_or_const_value_attribute): Handle CONST_VECTOR.
1878 2004-03-07 Aldy Hernandez <aldyh@redhat.com>
1880 * config/rs6000/rs6000.c (rs6000_parse_abi_options): SPE and
1881 AltiVec abi cannot co-exist.
1883 * config/rs6000/eabispe.h (SUBSUBTARGET_OVERRIDE_OPTIONS): Same.
1885 2004-03-07 Jan Hubicka <jh@suse.cz>
1887 * except.c (emit_to_new_bb_before): Break fallthru edges.
1889 2004-03-07 Stephane Carrez <stcarrez@nerim.fr>
1891 * config/m68hc11/m68hc11.md ("*lshrsi3_const"): Disable for 68HC12.
1892 ("*lshrsi3"): Also accept an immediate for 68HC12.
1893 ("*ashrsi3_const"): Likewise.
1894 ("*ashrsi3"): Likewise.
1895 ("*ashlsi3_const"): Likewise.
1896 ("*ashlsi3"): Likewise.
1897 ("cmphi_1_hc12"): Compare two hard register by pushing them and
1898 comparing with a pop; don't use a split for that.
1899 ("cmphi split"): Disable compare split for 68HC12.
1901 * config/m68hc11/m68hc11.c (m68hc11_notice_update_cc): Invalidate
1902 the status operands if they have side effects.
1904 2004-03-07 Kazu Hirata <kazu@cs.umass.edu>
1906 * defaults.h (LEGITIMIZE_ADDRESS): Provide a default
1908 * config/arc/arc.h, config/fr30/fr30.h, config/frv/frv.h,
1909 config/h8300/h8300.h, config/ia64/ia64.h,
1910 config/mcore/mcore.h, config/mmix/mmix.h,
1911 config/ns32k/ns32k.h, config/pdp11/pdp11.h,
1912 config/stormy16/stormy16.h, config/v850/v850.h,
1913 config/vax/vax.h (LEGITIMIZE_ADDRESS): Remove.
1914 * doc/tm.texi (LEGITIMIZE_ADDRESS): Mention the default
1917 2004-03-07 Roger Sayle <roger@eyesopen.com>
1919 * fold-const.c (fold) <IOR_EXPR>: Fold x | x as x.
1920 <XOR_EXPR>: Fold x ^ x as zero.
1921 <AND_EXPR>: Fold x & x as x.
1923 2004-03-07 Roger Sayle <roger@eyesopen.com>
1925 * fold-const.c (fold) <EQ_EXPR>: Rewrite optimization to transform
1926 "foo++ == const" into "++foo == const+incr".
1928 2004-03-07 Richard Sandiford <rsandifo@redhat.com>
1930 * config/mips/mips.c (mips_in_small_data_p): Return false if
1933 2004-03-06 Stephane Carrez <stcarrez@nerim.fr>
1935 * config/m68hc11/m68hc11.c (m68hc11_gen_movhi): Use 2,-sp to push
1937 (expand_prologue): Don't make an interrupt or a trap handler a far
1939 (m68hc11_initial_elimination_offset): Likewise.
1941 2004-03-06 Richard Henderson <rth@redhat.com>
1943 * config/alpha/alpha.c (alpha_in_small_data_p): False for functions.
1945 2004-03-06 Kazu Hirata <kazu@cs.umass.edu>
1947 * config/ns32k/ns32k-protos.h: Add a prototype for
1948 ns32k_notice_update_cc.
1949 * config/ns32k/ns32k.c (ns32k_notice_update_cc): New.
1950 * config/ns32k/ns32k.h (NOTICE_UPDATE_CC): Call
1951 ns32k_notice_update_cc.
1953 2004-03-06 Ulrich Weigand <uweigand@de.ibm.com>
1955 * config/s390/s390.md ("load_multiple", "*load_multiple_di",
1956 "*load_multiple_si"): Allow only if reload_completed.
1957 ("store_multiple", "*store_multiple_di", "*store_multiple_si"):
1960 2004-03-06 Kazu Hirata <kazu@cs.umass.edu>
1962 * config/vax/vax-protos.h: Add a prototype for
1963 vax_notice_update_cc.
1964 * config/vax/vax.c (vax_notice_update_cc): New.
1965 * config/vax/vax.h (NOTICE_UPDATE_CC): Call
1966 vax_notice_update_cc.
1968 2004-03-06 David Edelsohn <edelsohn@gnu.org>
1970 * collect2.c (main): Only export initfunc and finifunc if
1971 LD_INIT_SWITCH not defined.
1972 (scan_prog_file): Only export constructors and destructors if
1973 LD_INIT_SWITCH not defined. Only export symbols not found in
1976 2004-03-06 John David Anglin <dave.anglin@nrc-cnrc.gc.ca>
1978 * pa.md (icacheflush): Reorder operands to make match_scratch operand
1980 * pa.h (INITIALIZE_TRAMPOLINE): Remove unnecessary scratch argument
1981 from calls to gen_icacheflush.
1983 2004-03-06 Richard Henderson <rth@redhat.com>
1985 * config/alpha/alpha.h (MASK_LONG_DOUBLE_128): New.
1986 (TARGET_LONG_DOUBLE_128): New.
1987 (TARGET_SWITCHES): Add long-double-{128,64}.
1988 (TARGET_HAS_XFLOATING_LIBS): Default to TARGET_LONG_DOUBLE_128.
1989 (LONG_DOUBLE_TYPE_SIZE): Honor TARGET_LONG_DOUBLE_128.
1990 (LIBGCC2_LONG_DOUBLE_TYPE_SIZE): New.
1991 (WIDEST_HARDWARE_FP_SIZE): New.
1992 (TARGET_CPU_CPP_BUILTINS): Define __LONG_DOUBLE_128__.
1993 * config/alpha/alpha.c (override_options): Clear MASK_LONG_DOUBLE_128
1994 if TARGET_VAX_FLOAT.
1995 * config/alpha/osf5.h (LONG_DOUBLE_TYPE_SIZE): Remove.
1996 (TARGET_DEFAULT): Set MASK_LONG_DOUBLE_128.
1998 2004-03-06 Richard Henderson <rth@redhat.com>
2000 * config/alpha/alpha.c (alpha_swapped_comparison_operator): Fix
2001 botched rtx class conversion.
2003 2004-03-06 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
2005 * tree.h (BUILTIN_EXP10_P, BUILTIN_EXPONENT_P, BUILTIN_SQRT_P,
2006 BUILTIN_CBRT_P, BUILTIN_ROOT_P): New macros.
2008 * builtins.c (fold_builtin_logarithm, fold_builtin): Use new
2010 * fold-const.c (fold_mathfn_compare, fold): Likewise.
2012 2004-03-06 Eric Botcazou <ebotcazou@libertysurf.fr>
2015 * config/i386/i386.md (movv2di_internal): Conditionalize on
2016 TARGET_SSE, not TARGET_SSE2.
2018 2004-03-05 Chris Demetriou <cgd@broadcom.com>
2020 * config.gcc (mips64orion-*-elf*, mips64orionel-*-elf*): Delete
2023 2004-03-05 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
2025 * builtins.c: Consistently use logN not log* in comments.
2027 2004-03-05 Andreas Krebbel <krebbel1@de.ibm.com>
2029 * rtl.h (mem_expr_equal_p): Function prototype added.
2030 * cfgcleanup.c (merge_memattrs): New function.
2031 (flow_find_cross_jump): Call merge_memattrs for matching insns.
2032 * emit-rtl.c (mem_expr_equal_p): New function.
2034 2004-03-05 Ziemowit Laski <zlaski@apple.com>
2036 * objc/objc-act.c (synth_module_prologue): Const-qualify
2037 objc_selector type if using the GNU runtime; fix generated
2038 signatures for objc_msg_lookup and objc_msg_lookup_super
2039 to match what GNU ObjC headers provide; reformat and clean up.
2040 (synth_self_and_ucmd_args): Use previously constructed (and
2041 hence possibly const-qualified) objc_selector type.
2043 2004-03-05 Kazu Hirata <kazu@cs.umass.edu>
2045 * doc/tm.texi (HARD_REGNO_RENAME_OK): Document.
2047 2004-03-05 Jason Merrill <jason@redhat.com>
2049 * tree.h (TYPE_HASH): Use TYPE_UID.
2050 (TREE_HASH): New macro with old definition of TYPE_HASH.
2051 * tree.c (build_type_attribute_variant): Use iterative_hash_object.
2052 (build_array_type, build_function_type): Likewise.
2053 (build_method_type_directly): Likewise.
2054 (build_offset_type, build_complex_type): Likewise.
2055 (type_hash_list, attribute_hash_list): Likewise. Now static.
2056 * except.c: s/TYPE_HASH/TREE_HASH/.
2058 2004-03-05 Bob Wilson <bob.wilson@acm.org>
2060 * config/xtensa/xtensa.c (function_arg): Handle 16-byte aligned args.
2061 (xtensa_va_start): Initialize __va_stk to ($arg_ptr - 32). Adjust
2062 __va_ndx by 2 words when referencing an argument on the stack.
2063 (xtensa_va_arg): Handle 16-byte aligned args. Adjust __va_ndx by 2
2064 words when an arg on the stack is first seen.
2066 2004-03-05 Paul Brook <paul@codesourcery.com>
2068 * arm.h (ARM_FLAG_VFP): Remove.
2069 (ARM_FLAG_ATPCS, CIRRUS_FIX_INVALID_INSNS): Renumber.
2070 * netbsd-elf.h (ARM_FLAG_VFP): Remove.
2072 2004-03-05 Paul Brook <paul@codesourcery.com>
2074 * function.c (assign_parms): Include pretend alignment offset.
2076 2004-03-05 Richard Kenner <kenner@vlsi1.ultra.nyu.edu>
2078 * stor-layout.c (layout_type, case FUNCTION_TYPE): Make size
2079 FUNCTION_BOUNDARY, not POINTER_SIZE * 2.
2081 2004-03-05 Ian Lance Taylor <ian@wasabisystems.com>
2083 * configure.ac: When passing --enable-languages to subdir
2084 configure when host != build, make sure we don't pass an empty
2086 * configure: Regenerate.
2088 2004-03-05 Nathan Sidwell <nathan@codesourcery.com>
2091 * gcc.c (cc1_options): Robustify -auxbase-strip from multiple -o
2094 2004-03-05 Paolo Bonzini <bonzini@gnu.org>
2096 * simplify-rtx.c (simplify_relational_operation): If
2097 flag_wrapv is set, do not move terms between the two
2098 side of a relational operator.
2100 2004-03-05 Paolo Bonzini <bonzini@gnu.org>
2102 * rtlanal.c: Include target.h and output.h
2103 (rtx_cost, address_cost, default_address_cost): Move from...
2104 * cse.c (rtx_cost, address_cost, default_address_cost):
2106 * rtl.h (rtx_cost, address_cost): Move under rtlanal.c.
2107 * Makefile.in: Adjust dependencies.
2109 2004-03-05 Paolo Bonzini <bonzini@gnu.org>
2111 * cse.c (cse_end_of_basic_block): Make static.
2112 * local-alloc.c (function_invariant_p): Move to
2114 * loop.c (libcall_other_reg, record_excess_regs):
2116 * reload1.c (function_invariant_p): Moved here
2117 from local-alloc.c, made static.
2118 * rtl.h (cse_end_of_basic_block, function_invariant_p,
2119 libcall_other_reg, record_excess_regs): Remove
2122 2004-03-05 Kazu Hirata <kazu@cs.umass.edu>
2124 * config/m32r/m32r.c (signed_comparison_operator): Add a
2125 missing parenthesis.
2127 2004-03-04 Ian Lance Taylor <ian@wasabisystems.com>
2129 * ggc-common.c (gt_pch_restore): Don't unmap addr unless we are
2130 going to call mmap again. Read the file into the right place.
2131 Give a fatal error if we have to relocate.
2133 2004-03-04 Bob Wilson <bob.wilson@acm.org>
2135 * config/xtensa/xtensa.c (xtensa_return_in_msb): New function.
2136 (TARGET_RETURN_IN_MSB): Define to xtensa_return_in_msb.
2138 2004-03-05 Hans-Peter Nilsson <hp@axis.com>
2141 * config/fp-bit.c (_fpdiv_parts): Do not round when pack_d would
2142 round the same. When rounding, clear bits that would cause a
2143 second rounding in pack_d.
2144 (_fpmul_parts): Ditto. Remove #if 0:d code.
2146 2004-03-04 Ziemowit Laski <zlaski@apple.com>
2148 PR c++/14425, c++/14426
2149 * config/rs6000/altivec.h (vec_splat_s8, vec_splat_s16,
2150 vec_splat_s32, vec_splat_u8, vec_splat_u16, vec_splat_u32):
2151 Change C++ definitions to accept a 'const int' argument;
2152 the prototypes already do.
2153 * config/rs6000/rs6000.c (rs6000_common_init_builtins):
2154 Rename v4si_ftype_char, v8hi_ftype_char, v16qi_ftype_char,
2155 v4sf_ftype_v4si_char, v4si_ftype_v4sf_char, v4si_ftype_v4si_char,
2156 v8hi_ftype_v8hi_char, v16qi_ftype_v16qi_char,
2157 v16qi_ftype_v16qi_v16qi_char, v8hi_ftype_v8hi_v8hi_char,
2158 v4si_ftype_v4si_v4si_char and v4sf_ftype_v4sf_v4sf_char to
2159 end in ..._int; change them to accept an int instead of a char
2160 as the last parameter.
2162 2004-03-04 Phil Edwards <phil@codesourcery.com>
2164 * genmultilib: Change '=' to '-' when translating option names
2167 2004-03-04 Richard Kenner <kenner@vlsi1.ultra.nyu.edu>
2169 * expr.c (expand_expr_real, case COMPONENT_REF): Get proper type of
2170 stack slot for temp used for result of BLKmode but in integral mode.
2172 2004-03-04 Jan Hubicka <jh@suse.cz>
2174 * reload.c (find_reloads): Reorganize if seqeunce to switch.
2176 * cfgrtl.c (rtl_redirect_edge_and_branch): Set the source BB as dirty.
2177 (cfglayout_redirect_edge_and_branch): Set the source BB as dirty.
2179 2004-03-04 Steve Ellcey <sje@cup.hp.com>
2181 * config/ia64/ia64.md (divdf3_internal_thr): Fix algorithm.
2182 * testsuite/gcc.dg/20040303-1.c: New test.
2184 2004-03-04 Steven Bosscher <stevenb@suse.de>
2186 * ppro.md: Rewrite as a DFA pipeline description.
2187 * i386.md: Remove all uses of the ppro_uops attribute.
2188 * i386.c: (ix86_safe_ppro_uops, ix86_dump_ppro_packet,
2189 ix86_reorder_insn, ix86_sched_reorder_ppro, ix86_sched_init,
2190 ix86_sched_reorder, ix86_variable_issue,
2191 struct ix86_sched_data, TARGET_SCHED_VARIABLE_ISSUE,
2192 TARGET_SCHED_INIT, TARGET_SCHED_REORDER): Remove.
2193 (ia32_use_dfa_pipeline_interface): Add TARGET_PENTIUMPRO.
2194 (ia32_multipass_dfa_lookahead): Add TARGET_PENTIUMPRO.
2195 * athlon.md (athlon_ssecmp_load): Fix comment
2197 2004-03-04 Stuart Hastings <stuart@apple.com>
2199 * gcc/doc/invoke.texi: Document -mlongcall for Darwin/PPC.
2201 2004-03-04 Stuart Hastings <stuart@apple.com>
2203 * gcc/config/i386/darwin.h: Darwin/x86 doesn't support CPUs before
2204 686, tell Darwin assembler to allow prefetch insns, non-empty def
2205 of SUBTARGET_OPTION_TRANSLATE_TABLE.
2207 2004-03-04 DJ Delorie <dj@redhat.com>
2209 PR optimization/14282
2210 * sched-deps.c (sched_analyze_insn): Allow a stack adjustment
2211 between a call and the assignment of its return value.
2213 2004-03-04 Kazu Hirata <kazu@cs.umass.edu>
2215 * config/h8300/h8300.c: Put a comment for every function.
2217 2004-03-04 Kazu Hirata <kazu@cs.umass.edu>
2219 * config/h8300/h8300.md: Add comments about peephole2's.
2221 2004-03-04 Steven Bosscher <stevenb@suse.de>
2223 * i386.h (TARGET_CPU_DEFAULT_nocona): Fix value.
2225 2004-03-04 Jan Hubicka <jh@suse.cz>
2227 * cfgcleanup.c (thread_jump): Update call of cselib_init.
2228 * cselib.c (cselib_record_memory): New static variable.
2229 (cselib_lookup_mem, cselib_record_set, cselib_record_sets):
2230 Give up on memories when asked for.
2231 (cselib_init): Accept new argument.
2232 * cselib.h (cselib_init): Update prototype.
2233 * gcse.c (local_cprop_pass): Update call of cselib_init.
2234 * loop.c (load_mems): Update call of cselib_init.
2235 * postreload.c (reload_cse_regs_1): Update call of cselib_init.
2236 * sched-deps.c (sched_analyze): Update call of cselib_init.
2238 2004-03-04 David Edelsohn <edelsohn@gnu.org>
2241 * config/rs6000/rs6000.c (output_function_profiler): Append @plt
2244 2004-03-04 Josef Zlomek <zlomekj@suse.cz>
2247 * var-tracking.c (track_expr_p): Do not track variables which
2248 should be ignored for debugging purposes.
2250 2004-03-04 Alan Modra <amodra@bigpond.net.au>
2252 * real.c (encode_ibm_extended): Don't bother rounding low double.
2253 * c-cppbuiltin.c (builtin_define_float_constants): Tweak MAX
2254 when fmt->pnan < fmt->p.
2256 2004-03-04 Eric Christopher <echristo@redhat.com>
2258 * config/mips/mips.h (FUNCTION_ARG_REGNO_P): Fix to check
2259 only range of valid arg registers and fixed_regs.
2261 2004-03-04 Alan Modra <amodra@bigpond.net.au>
2264 * config/rs6000/rs6000.md (abstf2, abstf2+1): Delete define_insn.
2265 (abstf2, abstf2_internal): New define_expand.
2267 2004-03-04 Eric Botcazou <ebotcazou@libertysurf.fr>
2269 PR optimization/14235
2270 * expr.c (convert_move): Copy the source to a new pseudo
2271 when converting from a sub-word source to a larger-than-word
2272 register which conflicts with the source.
2274 2004-03-03 Zack Weinberg <zack@codesourcery.com>
2277 * c-decl.c (diagnose_mismatched_decls): Issue an error for two
2278 parameters with the same name, unless one is a forward decl.
2279 Do not issue a redundant-redeclaration warning for forward
2280 decls of parameters.
2282 2004-03-04 David Edelsohn <edelsohn@gnu.org>
2284 * doc/install.texi (*-ibm-aix*): Document use of Bash to speed up
2287 2004-03-03 Ian Lance Taylor <ian@wasabisystems.com>
2289 * ggc-zone.c (ggc_pch_write_object): Don't align file pointer.
2291 2004-03-04 Alan Modra <amodra@bigpond.net.au>
2293 * target-def.h (TARGET_OPTF): Delete.
2294 * c-opts.c (TARGET_OPTF): Define.
2296 2004-03-04 Jan Hubicka <jh@suse.cz>
2298 * cselib.c (cselib_finish): Fix another miss-application of my previous
2301 2004-03-03 Mike Stump <mrs@apple.com>
2303 Add framework support for darwin.
2305 * c-incpath.c: Include target.h and machmode.h.
2306 (add_path): Use a consistent style for cpp_dir. Initialize
2308 (add_cpp_dir_path): New.
2309 (register_include_chains): Add use of extra_includes callback.
2310 (hook_void_int): Add.
2311 (target_c_incpath): Add.
2312 * c-incpath.h (add_cpp_dir_path): New.
2313 (target_c_incpath_s): Add.
2314 (target_c_incpath): Add.
2315 (C_INCPATH_INIT): Add.
2316 * c-opts.c (c_common_missing_argument,
2317 c_common_handle_option): Add -F argument processing.
2318 * c.opt: Add -F argument processing.
2319 * gcc.c (trad_capable_cpp): Add -F argument processing.
2320 * cppfiles.c (find_file_in_dir): Update to use construct
2322 (search_path_exhausted, cpp_get_path, cpp_get_buffer,
2324 (_cpp_find_file): Use search_path_exhausted.
2325 (make_cpp_dir): Initialize construct to 0.
2326 * cpplib.h (missing_header_cb
2327 cpp_get_path, cpp_get_buffer, cpp_get_file, cpp_get_prev): New.
2328 (cpp_callbacks): Add missing_header
2329 (cpp_dir): Add construct.
2330 * target-def.h: (TARGET_OPTF): New.
2331 * hooks.c (hook_void_int, hook_void_charptr): Add.
2332 * hooks.h (hook_void_int, hook_void_charptr): Add.
2333 * Makefile.in (c-incpath.o) : Add $(TARGET_H) and
2334 $(MACHMODE_H) dependencies.
2335 * doc/invoke.texi (Darwin Options): Document -F.
2336 * doc/tm.texi (TARGET_EXTRA_INCLUDES): Add.
2338 * fix-header.c (target_c_incpath): Add.
2340 * config/darwin-c.c: Add c-incpath.h include.
2341 (using_frameworks, find_subframework_file,
2342 find_subframework_header, add_system_framework_path,
2343 frameworks_in_use, num_frameworks, max_frameworks,
2344 add_framework, find_framework, struct framework_header,
2345 framework_header_dirs, framework_construct_pathname,
2346 find_subframework_file, add_system_framework_path,
2347 add_framework_path, framework_defaults,
2348 darwin_register_frameworks, find_subframework_header): Add.
2349 * config/darwin.h (TARGET_EXTRA_INCLUDES, TARGET_OPTF): New.
2350 (TARGET_OPTION_TRANSLATE_TABLE): Add -framework support.
2351 (CPP_SPEC): Add __APPLE_CC__ support.
2352 * t-darwin (darwin-c.o): Add c-incpath.h dependency.
2354 2004-03-04 Jan Hubicka <jh@suse.cz>
2356 * cselib.c (cselib_finish): Fix miss-application of my previous
2359 2004-03-03 Kazu Hirata <kazu@cs.umass.edu>
2361 * hooks.c (hook_tree_tree_identity): New.
2362 * hooks.h: Add a prototype for hook_tree_tree_identity.
2363 * stmt.c (expand_asm_operands): Use targetm.md_asm_clobbers
2364 instead of MD_ASM_CLOBBERS.
2365 * system.h (MD_ASM_CLOBBERS): Poison.
2366 * target-def.h (TARGET_MD_ASM_CLOBBERS): New.
2367 (TARGET_INITIALIZER): Add TARGET_MD_ASM_CLOBBERS.
2368 * target.h (gcc_target): Add md_asm_clobbers.
2369 * config/i386/i386.c (TARGET_MD_ASM_CLOBBERS): New.
2370 (ix86_md_asm_clobbers): New.
2371 * config/i386/i386.h (MD_ASM_CLOBBERS): Remove.
2372 * doc/tm.texi (MD_ASM_CLOBBERS): Change to
2373 TARGET_MD_ASM_CLOBBERS.
2375 2004-03-03 Stuart Hastings <stuart@apple.com>
2377 * gcc/config.gcc: Arrange for Darwin/x86 to build libgcc_eh.a.
2379 2004-03-03 Eric Botcazou <ebotcazou@libertysurf.fr>
2381 * config/sparc/sparc.c (noov_compare64_op): Fix typo.
2383 * config/sparc/sparc.h (ASM_FLOAT): Delete.
2384 (ASM_DOUBLE): Likewise.
2385 (ASM_LONGDOUBLE): Likewise.
2386 * config/sparc/pbd.h (ASM_INT_OP): Delete.
2388 2003-03-03 Richard Henderson <rth@redhat.com>
2391 * cselib.c (cselib_record_sets): Don't record multiple sets in
2394 2004-03-03 Mostafa Hagog <mustafa@il.ibm.com>
2396 * common.opt: Add description of the new -fgcse-after-reload flag.
2398 * flags.h (flag_gcse_after_reload): Declaration of global variable.
2400 * gcse.c (reg_used_on_edge ,reg_set_between_after_reload_p,
2401 reg_used_between_after_reload_p, rtx get_avail_load_store_reg,
2402 is_jump_table_basic_block, bb_has_well_behaved_predecessors,
2403 get_bb_avail_insn, hash_scan_set_after_reload,
2404 compute_hash_table_after_reload, eliminate_partially_redundant_loads,
2405 gcse_after_reload, get_bb_avail_insn): New functions to implement
2407 (gcse_after_reload_main): New function, the main entry point to
2410 * rtl.h (gcse_after_reload_main): Declaration of the new function.
2412 * opts.c (common_handle_option): Handle the -fgcse-after-reload flag.
2414 * toplev.c (flag_gcse_after_reload): Initialization.
2416 * passes.c (rest_of_handl_gcse2): Call gcse_after_reload_main.
2418 * params.def (PARAM_GCSE_AFTER_RELOAD_PARTIAL_FRACTION,
2419 PARAM_GCSE_AFTER_RELOAD_CRITICAL_FRACTION): New parameters for tuning
2420 the gcse after reload optimization.
2422 * params.h (GCSE_AFTER_RELOAD_PARTIAL_FRACTION,
2423 GCSE_AFTER_RELOAD_CRITICAL_FRACTION): Two macros to access the tuning
2426 * doc/invoke.texi: Documentation for the new flag gcse-after-reload.
2428 2004-03-03 Nicolas Pitre <nico@cam.org>
2430 * config/arm/ieee754-df.S (muldf3, divdf3): Fix denormalization of
2431 small negative values.
2433 2004-03-03 Jan Hubicka <jh@suse.cz>
2435 * cselib.c (hash_table): Remove GTY marker.
2436 (reg_values): Turn into array.
2437 (used_regs): Likewise.
2438 (n_used_regs): New static variable.
2439 (reg_values_old): Kill.
2440 (clear_table): Update uses of arrays.
2441 (cselib_lookup): Likewise.
2442 (cselib_record_set): Likewise.
2443 (cselib_init): Likewise.
2444 (cselib_finish): Likewise.
2445 (cselib_udpate_varray_sizes): Kill.
2446 * cselib.h (cselib_update_varray_sizes): Kill.
2448 2004-03-03 Paul Brook <paul@codesourcery.com>
2450 * flow.c (ior_reg_cond, and_reg_cond): Remove stray ")".
2452 2004-03-03 Jan Hubicka <jh@suse.cz>
2454 * ggc-common.c (ggc_alloc_cleared_stat, ggc_realloc_stat):
2455 Rename from ...; make statistics transparent.
2456 (ggc_alloc_cleared, ggc_realloc_stat): ... these.
2457 (loc_descriptor): New structure.
2458 (hash_descriptor, eq_descriptor, loc_descriptor, cmp_statistics,
2460 New static function.
2461 (ggc_record_overhead, dump_statistics): New global function.
2462 * ggc-none.c (ggc_alloc_types_stat, ggc_alloc_stat, ggc_alloc_zone_stat,
2463 ggc_alloc_cleared_stat, ggc_realloc_stat, ggc_alloc_typed_stat): Rename
2464 from ...; accept locations
2465 (ggc_alloc_types, ggc_alloc, ggc_alloc_zone, ggc_alloc_cleared,
2466 ggc_realloc, ggc_alloc_typed): ... this one.
2467 from ...; accept locations
2468 * ggc-page.c (ggc_alloc_typed_stat, ggc_alloc_zone_stat,
2469 ggc_alloc_stat): Rename from ... ; pass locations
2470 * ggc-page.c (ggc_alloc_typed, ggc_alloc_zone, ggc_alloc):
2472 (ggc_alloc_stat): Record overehead.
2473 * ggc.h (ggc_alloc_types, ggc_alloc, ggc_alloc_zone, ggc_alloc_cleared,
2474 ggc_realloc, ggc_alloc_typed): Turn to macros
2475 (ggc_alloc_types_stat, ggc_alloc_stat, ggc_alloc_zone_stat,
2476 ggc_alloc_cleared_stat, ggc_realloc_stat, ggc_alloc_typed_stat): Declare.
2477 (dump_ggc_loc_satistics, ggc_record_overehead): Declare.
2478 * langhooks.h (lhd_make_node): Declare.
2479 (LANG_HOOKS_MAKE_TYPE): Default to new function,
2480 * langhooks.c (lhd_make_node): New.
2481 * rtl.c (rtx_alloc_stat, swallow_copy_rtx_stat): Rename from ... ; pass
2483 (rtx_alloc, swallow_copy_rtx): ... this one.
2484 * rtl.h (rtx_alloc, swallow_copy_rtx): Turn to macros.
2485 * rtl.c (rtx_alloc_stat, swallow_copy_rtx_stat): Declare.
2486 * toplpev.c (finalize): Dump stats.
2487 * tree.c (make_node_stat, copy_node_stat, make_tree_vec_stat,
2488 build_tree_list_stat, tree_cons_stat, build?_stat, build_decl_stat):
2489 Rename from ... ; pass locators.
2490 (make_node, copy_node, make_tree_vec, build_tree_list, tree_cons,
2491 build?, build_decl): Declare.
2492 * tree.h (make_node_stat, copy_node_stat, make_tree_vec_stat,
2493 build_tree_list_stat, tree_cons_stat, build?_stat, build_decl_stat):
2495 (make_node, copy_node, make_tree_vec, build_tree_list, tree_cons,
2496 build?, build_decl): New macros.
2497 * Makefile.in (RTL_H, TREE_H): Add statistics.h dependency.
2498 * statistics.h: New file.
2500 2004-03-03 Maciej W. Rozycki <macro@ds2.pg.gda.pl>
2501 Richard Sandiford <rsandifo@redhat.com>
2503 * config/mips/mips.h (MASK_FIX_SB1): Bump.
2504 (MASK_FIX_R4400, TARGET_FIX_R4400): New macros.
2505 (TARGET_SWITCHES): Add -mfix-r4400 and -mno-fix-r4400.
2506 * config/mips/mips.c (mips_output_division): Fill the branch delay
2507 slot with a nop if TARGET_FIX_R4000. Extend R4000 workarounds to
2509 (mips_output_division): Adjust accordingly.
2510 (override_options): Make -march=r4400 imply -mfix-r4400 by default.
2511 * doc/invoke.texi: Document -mfix-r4400 and new errata workarounds.
2513 2004-03-03 Paolo Bonzini <bonzini@gnu.org>
2515 * alias.c (rtx_equal_for_memref_p): Use predicates
2516 to test rtx classes and new rtx class codes, possibly
2517 splitting conditionals that tested against '<' and 'o'.
2518 * caller-save.c (save_call_clobbered_regs): Likewise.
2519 * combine.c (contains_muldiv, find_split_point, subst,
2520 combine_simplify_rtx, simplify_if_then_else,
2521 simplify_set, simplify_logical, expand_compound_operation,
2522 make_compound_operation, if_then_else_cond, known_cond,
2523 apply_distributive_law, cached_nonzero_bits,
2524 cached_num_sign_bit_copies, simplify_shift_const,
2525 gen_binary, simplify_comparison, update_table_tick,
2526 record_value_for_reg, get_lsat_value_validate): Likewise.
2527 * cse.c (mention_regs, find_best_addr, find_comparison_args,
2528 fold_rtx, cse_insn, invalidate_memory, cse_basic_block):
2530 * emit-rtl.c (copy_insn_1): Likewise.
2531 * expr.c (force_operand): Likewise.
2532 * final.c (final_scan_insn, get_mem_expr_from_op): Likewise.
2533 * flow.c (notice_stack_pointer_modification_1,
2534 invalidate_mems_from_autoinc, ior_reg_cond, not_reg_cond,
2535 and_reg_cond, elim_reg_cond): Likewise.
2536 * function.c (update_epilogue_consts): Likewise.
2537 * genattrtab.c (attr_rtx_1): Likewise.
2538 * genopinit.c (gen_insn): Likewise.
2539 * integrate.c (subst_constants): Likewise.
2540 * jump.c (reversed_comparison_code_parts,
2541 reversed_comparison_code, delete_related_insns,
2542 rtx_renumbered_equal_p): Likewise.
2543 * local-alloc.c (block_alloc): Likewise.
2544 * loop.c (rtx_equal_for_prefetch_p, maybe_eliminate_biv,
2545 canonicalize_condition): Likewise.
2546 * loop-iv.c (simplify_using_conditions, iv_number_of_iterations):
2548 * optabs.c (add_equal_node, expand_binop): Likewise.
2549 * predict.c (estimate_probability): Likewise.
2550 * ra-debug.c (ra_print_rtx_2op, ra_print_rtx): Likewise.
2551 * recog.c (validate_replace_rtx_1, comparison_operator,
2552 offsettable_address_p, constrain_operands): Likewise.
2553 * reg-stack.c (swap_rtx_condition_1, subst_stack_regs_pat):
2555 * regclass.c (scan_one_insn): Likewise.
2556 * regmove.c (stable_and_no_regs_but_for_p): Likewise.
2557 * regrename.c (kill_autoinc_value): Likewise.
2558 * reload.c (find_reusable_reload, find_reloads,
2559 reg_overlap_mentioned_for_reload_p): Likewise.
2560 * reload1.c (gen_reload, delete_address_reloads_1): Likewise.
2561 * rtl.c (copy_rtx): Likewise.
2562 * rtl.h (CONSTANT_P, INSN_P): Likewise.
2563 * rtlanal.c (commutative_operand_precedence): Likewise.
2564 * sched-deps.c (conditions_mutex_p): Likewise.
2565 * sched-rgn.c (is_cfg_nonregular): Likewise.
2566 * simplify-rtx.c (simplify_gen_binary,
2567 simplify_gen_relational, simplify_replace_rtx,
2568 simplify_unary_operation, simplify_binary_operation,
2569 simplify_ternary_operation, simplify_rtx): Likewise.
2570 * unroll.c (reg_dead_after_loop): Likewise.
2571 * config/alpha/alpha.c (alpha_swapped_comparison_operator,
2572 print_operand): Likewise.
2573 * config/arc/arc.c (proper_comparison_operator): Likewise.
2574 * config/arm/arm.c (arm_arm_address_cost, arm_select_cc_mode):
2576 * config/avr/avr.c (_reg_unused_after): Likewise.
2577 * config/frv/frv.c (frv_ifcvt_modify_tests,
2578 frv_ifcvt_modify_insn, frv_pack_insn): Likewise.
2579 * config/i386/i386.c (ix86_comparison_operator,
2580 ix86_carry_flag_operator, fcmov_comparison_operator,
2581 arith_or_logical_operator, print_operand,
2582 ix86_expand_binary_operator, ix86_binary_operator_ok):
2584 * config/i386/i386.md: Likewise.
2585 * config/ia64/ia64.c (not_postinc_memory_operand,
2586 ia64_print_operand, update_set_flags, errata_emit_nops):
2588 * config/ia64/ia64.h (PREFERRED_RELOAD_CLASS,
2589 CONSTRAINT_OK_FOR_S): Likewise.
2590 * config/ip2k/ip2k.c (mdr_resequence_xy_yx,
2591 mdr_try_move_dp_reload, ip2k_check_can_adjust_stack_ref,
2592 ip2k_xexp_not_uses_reg_for_mem, ip2k_xexp_not_uses_reg_p,
2593 ip2k_composite_xexp_not_uses_reg_p, ip2k_unary_operator):
2595 * config/iq2000/iq2000.c (cmp_op, symbolic_expression_p,
2596 eqne_comparison_operator, signed_comparison_operator):
2598 * config/mips/mips.c (cmp_op, symbolic_expression_p):
2600 * config/mmix/mmix (mmix_foldable_comparison_operator,
2601 mmix_comparison_operator): Likewise.
2602 * config/pa/pa.c (hppa_legitimize_address): Likewise.
2603 * config/rs6000/rs6000.c (stmw_operation,
2604 branch_comparison_operator, trap_comparison_operator,
2606 * config/rs6000/rs6000.h (SELECT_CC_MODE): Likewise.
2607 * config/s390/s390.c (s390_alc_comparison,
2608 s390_slb_comparison):L Likewise.
2609 * config/sh/sh.c (gen_block_redirect, reg_unused_after):
2611 * config/sparc/sparc.c (eq_or_neq, normal_comp_operator,
2612 noov_compare_op, noov_compare64_op, v9_regcmp_op,
2613 emit_hard_tfmode_operation, reg_unused_after)
2614 * doc/md.texi, doc/rtl.texi: Likewise.
2616 * ra-debug.c: Add 2004 to list of copyright years.
2617 * unroll.c: Likewise.
2619 * combine.c (simplify_logical): Remove dummy test,
2620 (apply_distributive_law): Fix typo in comment.
2621 GET_CODE (x) == AND so x is a commutative binary op.
2622 * jump.c (delete_related_insns): simplify loop
2623 condition, move testing of RTX codes inside the loop.
2624 (rtx_renumbered_equal_p): do not use RTX_CODE.
2625 * rtl.c (rtx_class): Declare as enum rtx_class.
2626 * rtl.def (EQ, NE, UNEQ, LTGT, UNORDERED, ORDERED):
2627 Move to RTX_COMM_COMPARE class.
2628 (HIGH, SYMBOL_REF, LABEL_REF, CONST, CONST_INT, CONST_DOUBLE):
2629 Move to RTX_CONST_OBJ class.
2630 * rtl.h (enum rtx_class): New declaration,
2631 (RTX_OBJ_MASK, RTX_OBJ_RESULT, RTX_COMPARE_MASK,
2632 RTX_COMPARE_RESULT, RTX_ARITHMETIC_MASK, RTX_ARITHMETIC_RESULT,
2633 RTX_BINARY_MASK, RTX_BINARY_RESULT, RTX_COMMUTATIVE_MASK,
2634 RTX_COMMUTATIVE_RESULT, RTX_NON_COMMUTATIVE_RESULT,
2635 RTX_EXPR_FIRST, RTX_EXPR_LAST, UNARY_P, BINARY_P,
2636 ARITHMETIC_P, COMMUTATIVE_ARITHMETIC_P, COMPARISON_P,
2637 SWAPPABLE_OPERANDS_P, NON_COMMUTATIVE_P, COMMUTATIVE_P,
2638 OBJECT_P): New macros.
2639 * config/sparc/sparc.c (noov_compare_op): Remove register
2642 2004-03-03 Kazu Hirata <kazu@cs.umass.edu>
2644 * target.h: Remove texi jargons in comments.
2646 2004-03-02 Kazu Hirata <kazu@cs.umass.edu>
2648 * config/h8300/lib1funcs.asm (___fixunssfsi): Change the
2652 2004-02-27 Kazu Hirata <kazu@cs.umass.edu>
2653 * config/h8300/fixunssfsi.c (__fixunssfsi): Enable on H8/300
2655 * config/h8300/lib1funcs.asm (___fixunssfsi): Remove.
2656 * config/h8300/t-h8300 (LIB1ASMFUNCS): Remove _fixunssfsi_asm.
2658 2004-03-02 Kazu Hirata <kazu@cs.umass.edu>
2660 * doc/md.texi (cbranchmode4): New.
2662 2004-03-02 Eric Christopher <echristo@redhat.com>
2664 * config/mips/mips16.S: Change fixsfsi and fixdfsi to
2666 * config/mips/mips.c (mips_init_libfuncs): Change accordingly.
2667 * config/mips/t-elf (LIB1ASMFUNCS): Ditto.
2668 * config/mips/t-isa3264 (LIB1ASMFUNCS): Ditto.
2669 * config/mips/t-r3900 (LIB1ASMFUNCS): Ditto.
2671 2004-03-02 Richard Henderson <rth@redhat.com>
2674 * coverage.c (coverage_counter_ref): Set MEM_NOTRAP_P.
2675 * optabs.c (prepare_cmp_insn): Force trapping memories to registers
2676 before the compare, if flag_non_call_exceptions.
2678 2004-03-02 Richard Henderson <rth@redhat.com>
2681 * stmt.c (expand_computed_goto): Do do_pending_stack_adjust before
2682 emitting the label, not after.
2684 2004-03-02 Stephane Carrez <stcarrez@nerim.fr>
2686 * config/m68hc11/m68hc11.c (m68hc11_addr_mode): New variable.
2687 (m68hc11_mov_addr_mode): Likewise.
2688 (m68hc11_override_options): Initialize them based on target.
2689 (register_indirect_p): Allow a MEM for indirect addressing modes and
2690 use flags to control what is allowed.
2691 (m68hc11_small_indexed_indirect_p): Use m68hc11_mov_addr_mode for
2692 supported addressing modes.
2693 (m68hc11_register_indirect_p): Use m68hc11_addr_mode.
2694 (go_if_legitimate_address_internal): Likewise.
2695 (m68hc11_indirect_p): Likewise and check the mode.
2696 (print_operand): Allow a (MEM (MEM)) and generate indirect addressing.
2698 2004-03-02 Kazu Hirata <kazu@cs.umass.edu>
2700 * builtins.c (BUILTIN_SETJMP_FRAME_VALUE): Remove.
2701 (expand_builtin_setjmp_setup): Use
2702 targetm.builtin_setjmp_frame_value instead of
2703 BUILTIN_SETJMP_FRAME_VALUE.
2704 * system.h (BUILTIN_SETJMP_FRAME_VALUE): Poison.
2705 * target-def.h (TARGET_BUILTIN_SETJMP_FRAME_VALUE): New.
2706 (TARGET_INITIALIZER): Add TARGET_BUILTIN_SETJMP_FRAME_VALUE.
2707 * target.h (gcc_target): Add builtin_setjmp_frame_value.
2708 * targhooks.c (default_builtin_setjmp_frame_value): New.
2709 * targhooks.h: Add a prototype for
2710 default_builtin_setjmp_frame_value.
2711 * doc/tm.texi (BUILTIN_SETJMP_FRAME_VALUE): Change to
2712 TARGET_BUILTIN_SETJMP_FRAME_VALUE.
2714 2004-03-02 Stephane Carrez <stcarrez@nerim.fr>
2716 * config/m68hc11/m68hc11.md (move peephole2): New peepholes to optimize
2718 (add peepholes): New peepholes to optimize sequences adding small
2720 (bset peepholes): New peepholes to transform an OR in a bset form
2721 (bclr peepholes): Likewise for bclr form.
2722 (cmp peepholes): New peepholes to avoid register copies when comparing.
2724 2004-03-02 Stephane Carrez <stcarrez@nerim.fr>
2726 * config/m68hc11/m68hc11.md ("*pushdi_internal"): New insn and split
2727 to separate push from moves.
2728 ("*pushdf_internal"): Likewise.
2729 ("*pushsf_internal"): Likewise.
2730 ("*pushsi_internal"): Likewise.
2731 ("movdi_internal"): Use define_insn_and_split; non push operand.
2732 ("movdf_internal"): Likewise.
2733 ("movsf_internal"): Likewise.
2734 ("movsi_internal"): Likewise.
2735 ("*movhi_68hc12", "*addhi3_68hc12"): Fix and tune constraints
2736 ("*addhi3", "*subhi3", "*andhi3_mem", "*iorhi3_mem"): Likewise.
2737 ("*ashlsi3_const1", "*lshrsi3_const1"): Likewise.
2739 2004-03-02 Stephane Carrez <stcarrez@nerim.fr>
2741 * config/m68hc11/m68hc11.md ("tstqi_z_used"): Use define_insn_and_split.
2742 ("cmphi_z_used", "cmpqi_z_used"): Likewise.
2743 ("movstrictsi", "movstricthi", "movstrictqi"): Likewise.
2744 ("anddi3", "andsi3", "iordi3", "iorsi3"): Likewise.
2745 ("xordi3", "xorsi3", "*logicalsi3_zexthi"): Likewise.
2746 ("*logicalsi3_zextqi", "*logicalhi3_zexthi_ashift8"): Likewise.
2747 ("logicalhi3_zexthi", "*logicalsi3_silshr16"): Likewise.
2748 ("*logicalsi3_silshl16", "*logicalsi3_silshl16_zext"): Likewise.
2749 ("*ashldi3_const32", "*ashldi3_const1", "addsi_silshr16"): Likewise.
2750 ("addsi_andshr16", "*ashlsi3_const16_zexthi"): Likewise.
2751 ("*lshrdi3_const32", "*lshrdi_const1"): Likewise.
2753 2004-03-02 Stephane Carrez <stcarrez@nerim.fr>
2755 * config/m68hc11/m68hc11.md (SOFT_TMP_REGNUM): Define.
2756 (SOFT_XY_REGNUM): Define.
2757 (cmp split): Use the above instead of hard coded numbers.
2758 (8-bit op split): No need to check the mode; allow Q_REG.
2759 (ashift split): Adjust the first operand if it uses the SP and we
2760 are pushing the shifted value.
2761 (plus shift split): Fix when a source is in register D+X.
2762 ("doloop_end"): Pass dummy arguments to gen_rtx_NE.
2764 2004-03-02 Stephane Carrez <stcarrez@nerim.fr>
2766 * config/m68hc11/m68hc11.c (m68hc11_check_z_replacement): Fix when
2767 comparing with Z register.
2769 2004-03-02 Zdenek Dvorak <rakdver@atrey.karlin.mff.cuni.cz>
2771 * cfgloop.h (struct loop_desc): Removed.
2772 (struct loop): Fields simple, desc and has_desc removed.
2773 (simple_loop_p, count_loop_iterations): Declaration removed.
2774 * cfgloopanal.c (struct unmark_altered_insn_data): Removed.
2775 (unmark_altered, blocks_invariant_registers, unmark_altered_insn
2776 blocks_single_set_registers, invariant_rtx_wrto_regs_p_helper,
2777 invariant_rtx_wrto_regs_p, test_for_iteration, constant_iterations,
2778 simple_loop_exit_p, variable_initial_value, variable_initial_values,
2779 simple_condition_p, simple_increment, count_strange_loop_iterations,
2780 inverse, fits_in_mode_p, simple_loop_p, count_loop_iterations):
2782 * loop-iv.c (check_simple_exit, find_simple_exit): Update comments.
2784 2004-03-02 Kazu Hirata <kazu@cs.umass.edu>
2786 * genattrtab.c: Don't handle MATCH_INSN.
2787 * genrecog.c: Likewise.
2788 * gensupport.c: Likewise.
2789 * rtl.def (match_insn): Remove.
2790 * doc/md.texi (match_insn, match_insn2): Remove.
2792 2004-03-02 Mark Mitchell <mark@codesourcery.com>
2794 * doc/c-tree.texi (DECL_ASSEMBLER_NAME): Mention that using this
2795 macro results in memory allocation.
2797 2004-03-02 David O'Brien <obrien@FreeBSD.org>
2799 * config/freebsd-spec.h (FBSD_DYNAMIC_LINKER): Add.
2800 * config/alpha/freebsd.h (SUBTARGET_EXTRA_SPECS): Define
2801 %(fbsd_dynamic_linker),
2802 (LINK_SPEC): Use %(fbsd_dynamic_linker), and sync style with
2803 config/i386/freebsd.h
2804 * config/arm/freebsd.h: Ditto.
2805 * config/i386/freebsd.h: Ditto.
2806 * config/i386/freebsd64.h: Ditto.
2807 * config/ia64/freebsd.h: Ditto.
2808 * config/rs6000/sysv4.h: Ditto.
2809 * config/sparc/freebsd.h: Ditto.
2811 2004-03-02 Loren James Rittle <ljrittle@acm.org>
2813 * gcc/doc/install.texi (*-*-freebsd*): Update target information.
2815 2004-03-02 Kazu Hirata <kazu@cs.umass.edu>
2817 * rtl.def (define_combine): Remove.
2819 2004-03-02 Kazu Hirata <kazu@cs.umass.edu>
2821 * config/h8300/h8300.md: Tweak formatting.
2823 2004-03-02 Kazu Hirata <kazu@cs.umass.edu>
2825 * config/h8300/h8300.md (*cmphi_h8300): Rename to
2827 (*cmphi_h8300hs): Rename to *cmphi_h8300hs_znvc.
2829 2004-03-01 Mark Mitchell <mark@codesourcery.com>
2832 * gcc.c (process_command): Remove const-qualification from argv.
2835 2004-03-02 Kazu Hirata <kazu@cs.umass.edu>
2837 * config/h8300/h8300.md (pushqi1_h8300hs): Rename to
2838 pushqi1_h8300hs_advanced. Adjust its caller.
2839 (pushhi1_h8300hs): Rename to pushhi1_h8300hs_advanced.
2842 2004-03-02 Nicolas Roche <roche@act-europe.fr>
2844 * Makefile.in (install-libgcc, install-multilib): Pass
2845 mkinstalldirs var to libgcc.mk.
2847 2004-03-01 Kazu Hirata <kazu@cs.umass.edu>
2849 * system.h (DBX_OUTPUT_STANDARD_TYPES): Poison.
2850 * doc/tm.texi (DBX_OUTPUT_STANDARD_TYPES): Remove.
2852 2004-03-01 Kazu Hirata <kazu@cs.umass.edu>
2854 * config/h8300/h8300.c (gtle_operator): Accept GT and LE.
2855 * config/h8300/h8300.md: Split several peephole2's, each into
2858 2004-03-02 Zdenek Dvorak <rakdver@atrey.karlin.mff.cuni.cz>
2860 * dominance.c (recount_dominator): Handle postdominators.
2862 2004-03-01 Richard Sandiford <rsandifo@redhat.com>
2864 * config/mips/mips-protos.h (enum mips_symbol_type): Move from mips.h.
2865 (NUM_SYMBOL_TYPES): Likewise.
2866 (SYMBOL_64_HIGH, SYMBOL_64_MID, SYMBOL_64_LOW): New symbol types.
2867 (mips_unspec_address): Declare.
2868 (mips_gotoff_page, mips_gotoff_global): Delete.
2869 * config/mips/mips.h (PREDICATE_CODES): Add general_symbolic_operand.
2870 * config/mips/mips.c (enum mips_symbol_type, NUM_SYMBOL_TYPES): Delete.
2871 (mips_symbolic_constant_p, mips_symbolic_address_p)
2872 (mips_symbol_insns): Handle new symbol types.
2873 (general_symbolic_operand): New predicate.
2874 (mips_unspec_address): Make extern.
2875 (mips_gotoff_page, mips_gotoff_global): Delete.
2876 (override_options): Allow -mabi=64 -mno-abicalls -mexplicit-relocs.
2877 Handle new symbol types.
2878 * config/mips/mips.md (*lea_high64, *lea64): New patterns.
2879 (*xgot_hi[sd]i, *xgot_lo[sd]i, *got_disp[sd]i, *got_disp[sd]i): Call
2880 mips_unspec_address directly.
2881 * doc/invoke.texi: Remove the -mabi=64 -mno-abicalls exception from
2882 the documentation of -mexplicit-relocs.
2884 2004-03-01 Jeff Law <law@redhat.com>
2886 * fold-const.c (fold): An equality comparison of a non-weak object
2887 against zero has a known result. Similarly an equality comparison
2888 of the address of two non-weak, unaliased symbols has a known result.
2890 * ggc-page.c (struct page_entry): New field PREV.
2891 (ggc_alloc): Update PREV field appropriately.
2892 (sweep_pages): Likewise.
2893 (ggc_free): Likewise. Use PREV field rather than loop to
2894 improve ggc_free performance.
2896 2004-03-01 Richard Sandiford <rsandifo@redhat.com>
2898 * config/mips/mips.c (mips_output_division): Use the division
2899 instruction to fill the delay slot of a zero check.
2900 (mips_idiv_insns): Adjust accordingly.
2902 2004-03-01 Nathanael Nerode <neroden@gcc.gnu.org>
2904 * config.gcc: Create a default tmake_file for linux, and use
2905 it in all but two linux clauses. Comment those two.
2907 2004-03-01 Paolo Bonzini <bonzini@gnu.org>
2909 * combine.c (try_combine): Do not refer to is_replaced.
2910 (gen_lowpart_for_combine): Perverse subregs now have a
2911 more politically correct name.
2912 * cse.c (cse_insn): Likewise.
2913 * jump.c: Fix bogus reference to delete_insn.
2915 2004-02-29 Mark Mitchell <mark@codesourcery.com>
2918 * dwarf2out.c (gen_enumeration_type_die): Output all enumeration
2919 constants as signed values.
2922 * c-tree.h (readonly_warning): Rename to ...
2923 (readonly_error): ... this.
2924 * c-typeck.c (build_unary_op): Adjust accordingly.
2925 (readonly_warning): Rename to ...
2926 (readonly_error): ... this and issue errors, not warnings.
2927 (build_modify_expr): Call readonly_error, not readonly_warning.
2928 (c_expand_asm_operands): Likewise.
2929 * tree-inline.c (optimize_inline_calls): Do not inline functions
2930 after errors have occurred.
2932 2004-02-29 Nathanael Nerode <neroden@gcc.gnu.org>
2934 * configure.ac: Rearrange some threading code for clarity;
2935 add section comment.
2936 * configure: Regenerate.
2938 2004-02-29 Kazu Hirata <kazu@cs.umass.edu>
2940 * passes.c, config/frv/frv.c, config/sh/sh.c: Fix comment
2942 * doc/cppopts.texi: Fix a typo.
2944 2004-02-29 Kazu Hirata <kazu@cs.umass.edu>
2946 * config/i386/i386.md: Fix formatting.
2948 2004-02-29 Nathanael Nerode <neroden@gcc.gnu.org>
2950 * configure.ac: Add some comments delineating sections of code.
2952 * doc/install.texi: Note that libada uses autoconf 2.57 also.
2954 * doc/install.texi: Fix idiot typo in previous commit.
2956 * doc/install.texi: Update for conversion of intl to autoconf 2.57.
2958 2004-02-29 Kazu Hirata <kazu@cs.umass.edu>
2960 * config/h8300/h8300.md: Add comments about peephole2's.
2962 2004-02-29 Kazu Hirata <kazu@cs.umass.edu>
2964 * config/h8300/h8300.md: Tweak operand numbers of some
2967 2004-02-29 Kazu Hirata <kazu@cs.umass.edu>
2969 * config/h8300/h8300.md: Tweak comments about peephole2's.
2971 2004-02-29 Waldek Hebisch <hebisch@math.uni.wroc.pl>
2974 * function.c (uninitialized_vars_warning): Use DECL_RTL_SET_P
2975 instead of testing whether DECL_RTL is not NULL.
2977 2004-02-28 Kazu Hirata <kazu@cs.umass.edu>
2979 * config/sh/sh.c: Fix formatting.
2981 2004-02-28 Kazu Hirata <kazu@cs.umass.edu>
2983 * config/sh/sh.c: Convert to ISO-C.
2985 2004-02-28 Andrew Pinski <pinskia@physics.uc.edu>
2987 * c-typeck.c (tagged_types_tu_compatible_p): Fix pasto in
2990 * config/darwin.h (machopic_finish): Output stub even if the
2991 symbol is already defined.
2993 2004-02-28 John David Anglin <dave.anglin@nrc-cnrc.gc.ca>
2995 * pa64-hpux.h (LIB_SPEC): Fix linking under HP-UX 11.00 with -p and -pg.
2997 2004-02-28 Kazu Hirata <kazu@cs.umass.edu>
2999 * genattr.c (main): Don't define
3000 TRADITIONAL_PIPELINE_INTERFACE or DFA_PIPELINE_INTERFACE.
3001 * system.h (TRADITIONAL_PIPELINE_INTERFACE): Poison.
3002 (DFA_PIPELINE_INTERFACE): Likewise.
3003 * doc/tm.texi (TRADITIONAL_PIPELINE_INTERFACE): Remove.
3004 (DFA_PIPELINE_INTERFACE): Likewise.
3006 2004-02-28 Richard Sandiford <rsandifo@redhat.com>
3008 * config/mips/mips.md (tstsi, tstdi): Delete.
3010 2004-02-28 Maciej W. Rozycki <macro@ds2.pg.gda.pl>
3012 * config/mips/mips.c (override_options): Remove an obsolete
3013 duplicate definition of the "e" constraint.
3014 * config/mips/mips.h: Update a comment accordingly.
3016 2004-02-28 Maciej W. Rozycki <macro@ds2.pg.gda.pl>
3018 * config/mips/mips.md: Complete the unfinished R4000
3019 multiply/shift errata workaround. Improve documentation.
3020 (hazard): Use TARGET_FIX_R4000 to decide whether an "imul" instruction
3022 (mulsi3, mulsi3_internal, mulsi3_r4000): Use TARGET_FIX_R4000.
3023 (muldi3, muldi3_internal): Likewise.
3024 (muldi3_internal2): Remove, replacing with...
3025 (muldi3_mult3, muldi3_r4000): ...these new patterns.
3026 (mulsidi3): Take the errata into account.
3027 (mulsidi3_32bit): Remove, replacing with...
3028 (mulsidi3_32bit_internal, mulsidi3_32bit_r4000): ...these new patterns.
3029 (mulsidi3_64bit, mulsidi3_64bit_parts): Disable if TARGET_FIX_R4000.
3030 (umulsidi3): Take the errata into account.
3031 (umulsidi3_32bit): Remove, replacing with..
3032 (umulsidi3_32bit_internal, umulsidi3_32bit_r4000): ...these patterns.
3033 (umulsi3_highpart, umulsi3_highpart_internal): Disable if
3035 (smulsi3_highpart, smulsi3_highpart_internal): Likewise.
3036 (smuldi3_highpart, umuldi3_highpart): Likewise.
3037 * doc/invoke.texi: Document the errata workaround.
3039 2004-02-28 Maciej W. Rozycki <macro@ds2.pg.gda.pl>
3041 * config/mips/mips-protos.h (mips_idiv_insns): Declare.
3042 * config/mips/mips.h (MASK_FIX_SB1): Bump.
3043 (MASK_FIX_R4000, TARGET_FIX_R4000): New macros.
3044 (TARGET_SWITCHES): Add -mfix-r4000 and -mno-fix-r4000.
3045 * config/mips/mips.c (mips_idiv_insns): New function.
3046 (override_options): Make -march=r4000 imply -mfix-r4000 by default.
3047 (mips_output_division): Add a workaround for the R4000 divide/shift
3049 * config/mips/mips.md (length): Use mips_idiv_insns() to calculate
3050 the length of an "idiv" instruction.
3051 * doc/invoke.texi: Document the new switches.
3053 2004-02-28 Kazu Hirata <kazu@cs.umass.edu>
3055 * doc/tm.texi (IS_COSTLY_DEPENDENCE): Change to
3056 TARGET_SCHED_IS_COSTLY_DEPENDENCE.
3058 2004-02-28 Zdenek Dvorak <rakdver@atrey.karlin.mff.cuni.cz>
3060 PR optimization/14229
3061 * cfgrtl.c (rtl_tidy_fallthru_edge): Do not fail for !onlyjump jump.
3063 2004-02-28 Eric Botcazou <ebotcazou@act-europe.fr>
3065 * fold-const.c (fold): Strip NOPs that change the signedness
3066 for RSHIFT too. Expand comment.
3068 2004-02-27 Ian Lance Taylor <ian@wasabisystems.com>
3070 PR optimization/7871
3071 * flow.c (mark_set_1): Don't add LOG_LINKS for global registers
3072 from or to call insns.
3074 2004-02-27 Eric Botcazou <ebotcazou@libertysurf.fr>
3076 PR optimization/7871
3077 * flow.c (propagate_one_insn): Interpret calls as setting global
3078 registers, not merely clobbering them.
3080 2004-02-27 Dale Johannesen <dalej@apple.com>
3082 * config/darwin.c (machopic_output_possible_stub_label): Remove.
3083 config/darwin-protos.h: Ditto.
3084 config/darwin.h: Remove call to it.
3085 * combine.c (distribute_notes): Do not place a REG_DEAD note
3086 when value is both set and used.
3088 2004-02-27 Kazu Hirata <kazu@cs.umass.edu>
3090 * config/h8300/fixunssfsi.c (__fixunssfsi): Enable on H8/300
3092 * config/h8300/lib1funcs.asm (___fixunssfsi): Remove.
3093 * config/h8300/t-h8300 (LIB1ASMFUNCS): Remove _fixunssfsi_asm.
3095 2004-02-27 Andrew Pinski <apinski@apple.com>
3097 * c-typeck.c (tagged_types_tu_compatible_p) <ENUMERAL_TYPE>:
3098 Speedup common case of the type values being in the same order.
3100 2004-02-27 Steve Ellcey <sje@cup.hp.com>
3102 * config/ia64/ia64.h (no-inline-float-divide): New option.
3103 * config/ia64/ia64.h (no-inline-int-divide): New option.
3104 * config/ia64/ia64.h (no-inline-sqrt): New option.
3105 (TARGET_DEFAULT): Add MASK_INLINE_FLOAT_DIV_THR to define.
3106 * config/ia64/hpux.h (TARGET_DEFAULT): Ditto.
3107 * config/ia64/ia64.c (ia64_override_options): Modify error
3108 checking for inlined division/sqrt.
3110 2004-02-27 Kazu Hirata <kazu@cs.umass.edu>
3112 * bb-reorder.c, cfgbuild.c, diagnostic.c, explow.c, profile.c,
3113 ra-build.c, read-rtl.c, tracer.c, unwind-dw2-fde-glibc.c,
3114 value-prof.c, config/darwin-protos.h, config/frv/frv-abi.h,
3115 config/i386/pmmintrin.h, config/pa/pa-hpux.h: Update
3118 2004-02-27 Paul Brook <paul@codesourcery.com>
3120 * function.c (assign_parms): Don't count pretend args for alignment.
3122 2004-02-27 Richard Henderson <rth@redhat.com>
3124 * passes.c: New file.
3125 * Makefile.in (OBJS-common): Add it.
3126 * diagnostic.c (rtl_dump_and_exit): Move decl ...
3127 * flags.h (rtl_dump_and_exit): ... here.
3128 * output.h (size_directive_output, last_assemble_variable_decl):
3130 * rtl.h (reg_alloc): Move from toplev.c.
3131 * toplev.c (HAVE_conditional_execution, DUMPFILE_FORMAT,
3132 struct dump_file_info, enum dump_file_index, dump_file_tbl,
3133 open_dump_file, close_dump_file, rest_of_decl_compilation,
3134 rest_of_type_compilation, rest_of_handle_final,
3135 rest_of_handle_delay_slots, rest_of_handle_stack_regs,
3136 rest_of_handle_variable_tracking, rest_of_handle_machine_reorg,
3137 rest_of_handle_new_regalloc, rest_of_handle_old_regalloc,
3138 rest_of_handle_regrename, rest_of_handle_reorder_blocks,
3139 rest_of_handle_sched, rest_of_handle_sched2, rest_of_handle_regmove,
3140 rest_of_handle_tracer, rest_of_handle_if_conversion,
3141 rest_of_handle_if_after_combine, rest_of_handle_web,
3142 rest_of_handle_branch_prob,
3143 rest_of_handle_value_profile_transformations, rest_of_handle_cfg,
3144 rest_of_handle_addressof, rest_of_handle_sibling_calls,
3145 rest_of_handle_jump_bypass, rest_of_handle_inlining,
3146 rest_of_handle_null_pointer, rest_of_handle_combine,
3147 rest_of_handle_life, rest_of_handle_cse, rest_of_handle_cse2,
3148 rest_of_handle_gcse, rest_of_handle_loop_optimize,
3149 rest_of_handle_loop2, rest_of_compilation): Move to passes.c.
3150 (decode_d_option): Use enable_rtl_dump_file.
3151 (compile_file, finalize, do_compile): Move profile+combine+graph
3152 cleanup to finish_optimization_passes.
3153 * toplev.h (init_optimization_passes, finish_optimization_passes,
3154 enable_rtl_dump_file): Declare.
3156 2004-02-27 Eric Botcazou <ebotcazou@act-europe.fr>
3157 Roger Sayle <roger@eyesopen.com>
3159 * fold-const.c (fold): Revert 2004-02-25 change. Use the original
3160 operands to build a tree with swapped operands.
3161 * expr.c (expand_expr_real) <MAX_EXPR>: Consistently use the
3162 'unsignedp' predicate to specify the signedness.
3164 2004-02-27 Kazu Hirata <kazu@cs.umass.edu>
3166 * c-decl.c, c-ppoutput.c, combine.c, cppfiles.c, dwarf2out.c,
3167 expr.c, fold-const.c, gcc.c, haifa-sched.c, loop-iv.c,
3168 params.def, read-rtl.c, rtl.c, rtlanal.c, toplev.c: Fix
3169 comment typos and formatting. Follow spelling conventions.
3171 2004-02-26 Aldy Hernandez <aldyh@redhat.com>
3173 * config/rs6000/rs6000.md: Add fixuns_truncsfsi2 and
3176 * config/rs6000/spe.md: Delete spe_efsctuiz.
3177 Add spe_fixuns_truncsfsi2.
3178 Add spe_fix_truncsfsi2.
3180 2004-02-26 Eric Christopher <echristo@redhat.com>
3182 * c-lex.c (c_lex_string_translate): New variable.
3183 (lex_string): Use to determine string translation.
3184 * c-pragma.h: Prototype.
3185 * c-parse.in (start_string_translation): New. Set above.
3186 (stop_string_translation): Ditto.
3187 (attribute, attribute_list, asm_def, asm_stmt,
3188 asm_operand): Use above functions.
3189 * cp/parser.c (cp_parser_declaration): Translate strings
3190 unless token is RID_EXTERN. Set c_lex_string_translate
3192 (cp_parser_asm_definition): Only translate argument strings
3194 (cp_parser_asm_operand_list): Ditto.
3195 (cp_parser_attribute_list): Do not translate attribute strings.
3197 2004-02-26 Kazu Hirata <kazu@cs.umass.edu>
3199 * stmt.c (expand_start_case_dummy): Remove.
3200 * tree.h: Remove the corresponding prototype.
3202 2004-02-26 Kazu Hirata <kazu@cs.umass.edu>
3204 * builtins.c (apply_args_register_offset): Remove.
3205 * tree.h: Remove the corresponding prototype.
3207 2004-02-26 Kazu Hirata <kazu@cs.umass.edu>
3209 * stor-layout.c (is_pending_size): Remove.
3210 * tree.h: Remove the corresponding prototype.
3212 2004-02-26 Kazu Hirata <kazu@cs.umass.edu>
3214 * recog.c (validate_replace_src): Remove.
3215 * recog.h: Remove the corresponding prototype.
3217 2004-02-26 Kazu Hirata <kazu@cs.umass.edu>
3219 * calls.c: Don't reference FINAL_REG_PARM_STACK_SPACE or
3220 MAYBE_REG_PARM_STACK_SPACE.
3221 * function.c: Likewise.
3222 * system.h (FINAL_REG_PARM_STACK_SPACE): Poison.
3223 (MAYBE_REG_PARM_STACK_SPACE): Likewise.
3224 * doc/tm.texi (FINAL_REG_PARM_STACK_SPACE): Remove.
3225 (MAYBE_REG_PARM_STACK_SPACE): Likewise.
3227 2004-02-26 Kazu Hirata <kazu@cs.umass.edu>
3229 * c-decl.c (c_expand_deferred_function): Remove.
3230 * c-tree.h: Remove the corresponding prototype.
3232 2004-02-26 Kazu Hirata <kazu@cs.umass.edu>
3234 * postreload.c (reload_cse_move2add): Generate just a PLUS
3235 instead of an entire SET.
3237 2004-02-26 Jan Hubicka <jh@suse.cz>
3239 * config.gcc: Add support for nocoma/prescott/pentium-m/pentium3m
3241 * i386.c (override_options): Add support for new CPUs.
3242 * i386.h (TARGET_CPU_DEFAULT_NAMES): New names.
3243 (TARGET_CPU_DEFAULT_pentium_m, TARGET_CPU_DEFAULT_pentium4e): New
3245 * invoke.texi: Extend documentation of -mtune/-march for new CPUs.
3247 2004-02-26 Bob Wilson <bob.wilson@acm.org>
3249 * config/xtensa/xtensa.h (TARGET_CPU_CPP_BUILTINS): Define __xtensa__.
3251 2004-02-26 Eric Botcazou <ebotcazou@act-europe.fr>
3253 * config/sparc/sparc-protos.h (sparc_emit_floatunsdi): Add 'mode'.
3254 (sparc_emit_fixunsdi): New prototype.
3255 * config/sparc/sparc.c (sparc_emit_floatunsdi): Use 'mode' argument.
3256 (sparc_emit_fixunsdi): New function.
3257 * config/sparc/sparc.md (floatunsdisf2): Use 'general_operand' for
3258 operand 1. Pass SFmode to sparc_emit_floatunsdi.
3259 (floatunsdidf2): Use 'general_operand' for operand 1. Pass DFmode
3260 to sparc_emit_floatunsdi.
3261 (fixuns_truncsfdi2): New expander.
3262 (fixuns_truncdfdi2): Likewise.
3264 2004-02-26 Alan Modra <amodra@bigpond.net.au>
3266 * gcse.c (delete_null_pointer_checks_1): Do not delete CC setter
3269 2004-02-25 Richard Henderson <rth@redhat.com>
3271 * explow.c (force_reg): Call mark_reg_pointer as appropriate.
3272 * config/alpha/alpha.c (alpha_emit_conditional_branch): Don't
3273 use (op0-op1) == 0 if op0 is a pointer.
3274 * config/alpha/alpha.md (cmpdi): Use some_operand.
3275 (three comparison combine splits): Remove.
3277 2004-02-25 Richard Henderson <rth@redhat.com>
3280 * c-common.c (handle_alias_attribute): Reject the attribute if
3281 current_function_decl is set.
3283 2004-02-25 Kelley Cook <kcook@gcc.gnu.org>
3285 * config.gcc: Add comment describing extra_gcc_objs.
3286 i[34567]86-*-cygwin*): Replace host_extra_gcc_objs with extra_gcc_objs.
3287 * configure.ac (extra_gcc_objs): New substitution variable.
3288 (host_extra_gcc_objs): Don't substitute.
3289 * configure: Regenerate.
3290 * Makefile.in: Use extra_gcc_objs.
3292 2004-02-25 Kelley Cook <kcook@gcc.gnu.org>
3294 * doc/contrib.texi: Add an entry for myself.
3296 2004-02-25 Jan Hubicka <jh@suse.cz>
3298 * basic-block.h (make_eh_edge, break_superblocks): Declare.
3299 * cfgbuild.c (make_eh_edge): Make global.
3300 * cfglayout.c (break_superblocks): Likewise; fix memory leak.
3301 * except.c (build_post_landing_pads, connect_post_landing_pads,
3302 dw2_build_landing_pads, sjlj_emit_function_enter,
3303 sjlj_emit_function_exit, sjlj_emit_dispatch_table,
3304 sjlj_build_landing_pads): Update CFG.
3305 (emit_to_new_bb_before): New function.
3306 (finish_eh_generation): Do not rebuild the CFG.
3308 2004-02-25 John David Anglin <dave.anglin@nrc-cnrc.gc.ca>
3310 * config.gcc (hppa*-*-*, parisc*-*-*): Add MASK_BIG_SWITCH to all
3311 target_cpu_default defines.
3312 * pa-hpux.h (TARGET_DEFAULT): Add MASK_BIG_SWITCH to define.
3313 * pa.h (TARGET_DEFAULT): Likewise.
3315 2004-02-25 Eric Botcazou <ebotcazou@act-europe.fr>
3317 * fold-const.c (fold): Treat MAX_EXPR and MIN_EXPR like
3318 comparisons with regard to signedness.
3320 2004-02-25 Richard Earnshaw <rearnsha@arm.com>
3322 * arm.c (thumb_legitimize_address): New function.
3323 * arm-protos.h: Prototype it.
3324 * arm.h (THUMB_LEGITIMIZE_ADDRESS): Define.
3325 (LEGITIMIZE_ADDRESS): Use it.
3327 2004-02-25 J"orn Rennecke <joern.rennecke@superh.com>
3329 * reload1.c (reload): Only spill eliminable register with multiple
3330 adjacent elimination alternatives if all alternatives fail.
3332 2004-02-25 Richard Earnshaw <rearnsha@arm.com>
3334 * arm.c (arm_legitimate_index_p): For QImode the range of an offset
3335 is -4095...+4095 inclusive.
3337 2004-02-25 Eric Botcazou <ebotcazou@libertysurf.fr>
3339 * doc/install.texi (sparc-sun-solaris2* specific notes): Document
3340 the bootstrap failure with Sun CC 5.4 and 5.5.
3342 2004-02-24 Kazu Hirata <kazu@cs.umass.edu>
3344 * cse.c (cse_change_cc_mode_insns): Stop at any instruction
3345 which modifies NEWREG.
3346 (cse_condition_code_reg): Update the mode of CC_REG in
3347 CC_SRC_INSN on our own.
3349 2004-02-24 Michael Matz <matz@suse.de>
3351 * config/i386/i386.c (ix86_comp_type_attributes): Check for
3354 2004-02-24 Richard Henderson <rth@redhat.com>
3356 * toplev.c (dump_file_tbl): Rename from dump_file.
3357 * bb-reorder.c, bt-load.c, cfgcleanup.c, cfglayout.c, cfgloopanal.c,
3358 cfgloopmanip.c, cfgrtl.c, config/arm/arm.c, config/frv/frv.c,
3359 config/i386/i386.c, config/ia64/ia64.c, config/mips/mips.c,
3360 config/sh/sh.c, cse.c, flow.c, ifcvt.c, loop-iv.c, loop-unroll.c,
3361 loop-unswitch.c, output.h, predict.c, profile.c, ra-build.c,
3362 ra-colorize.c, ra-debug.c, ra-rewrite.c, ra.c, regrename.c, reload1.c,
3363 toplev.c, tracer.c, value-prof.c, var-tracking.c, web.c:
3364 s/rtl_dump_file/dump_file/g.
3366 2004-02-24 Aldy Hernandez <aldyh@redhat.com>
3368 * config/rs6000/spe.md (spe_fix_truncsfsi2): Delete.
3369 (spe_fixuns_truncsfsi2): Delete.
3371 * config/rs6000/rs6000.md (fix_truncsfsi2): Delete.
3372 (fixuns_truncsfsi2): Delete.
3374 2004-02-24 Josef Zlomek <zlomekj@suse.cz>
3377 * rtlanal.c (replace_label): Fix replacing labels in constant pool.
3379 2004-02-24 Geoffrey Keating <geoffk@apple.com>
3381 * config/darwin.h (TARGET_HAS_F_SETLKW): Define.
3383 2004-02-24 Jason Merrill <jason@redhat.com>
3385 * tree.c (check_qualified_type): New fn.
3386 (get_qualified_type): Use it. If type already has the desired
3387 quals, just return it.
3388 * tree.h: Declare it.
3390 2003-02-24 Sanjiv Kumar Gupta <sanjivg@noida.hcltech.com>
3392 * target-def.h (TARGET_SCHED_INIT_GLOBAL,
3393 TARGET_SCHED_FINISH_GLOBAL): New macros.
3395 * target.h (md_init_global, md_finish_global): Function
3396 declarations corresponding to new target macros.
3398 * haifa-sched.c (sched_init, sched_finish): Allow target to
3399 call the new schedular hooks.
3401 * flow.c (recompute_reg_usage): Add PROP_DEATH_NOTES flag in
3402 call to update_life_info.
3404 * config/sh/sh.h (OVERRIDE_OPTIONS): Re-enable
3405 flag_schedule_insns for SH4.
3407 * config/sh/sh.c (sh_md_init_global, sh_md_finish_global,
3408 find_set_regmode_weight, find_insn_regmode_weight,
3409 find_regmode_weight), sh_md_init, sh_dfa_new_cycle,
3410 sh_variable_issue, high_pressure, ready_reorder,
3411 rank_for_reorder, swap_reorder, sh_reorder, sh_reorder2): New
3412 functions used to throttle the insn movement in first
3413 scheduling pass for SH.
3415 * gcc/doc/tm.texi: Document TARGET_SCHED_INIT_GLOBAL and
3416 TARGET_SCHED_FINISH_GLOBAL.
3418 2004-02-24 Alexandre Oliva <aoliva@redhat.com>
3420 Implement FR-V FDPIC ABI support for frv-uclinux and frv-linux.
3421 2004-02-05 Alexandre Oliva <aoliva@redhat.com>
3422 * config/frv/frv.c (frv_emit_movsi): Use GOT relocations for
3423 symbols in sections named by the user.
3424 2004-01-30 Alexandre Oliva <aoliva@redhat.com>
3425 * config/frv/linux.h (TARGET_OS_CPP_BUILTINS): New.
3426 2004-01-27 Alexandre Oliva <aoliva@redhat.com>
3427 * config.gcc (frv-*-*linux*): Handle like *-*-linux*.
3428 * config/frv/t-linux (EXTRA_MULTILIB_PARTS): Remove, obviated by
3430 2004-01-20 Alexandre Oliva <aoliva@redhat.com>
3431 * config/frv/frv.md (symGOT2reg_hilo, symGOTOFF2reg_hilo): Add
3432 one more pseudo to further improve code generation.
3433 2004-01-19 Alexandre Oliva <aoliva@redhat.com>
3434 * config/frv/frv.md (movdi_ldd): Introduce explicit indirection
3436 2004-01-16 Alexandre Oliva <aoliva@redhat.com>
3437 * config/frv/frv.c (frv_legitimate_address_p): Added
3438 allow_double_reg_p argument. Adjust all callers. Use it to
3439 decide whether to enable double-register indirect addressing.
3440 (frv_funcdesc_alias_set): Remove.
3441 (frv_expand_fdpic_call): Force non-SYMBOL_REF operand into
3442 register. Emit movdi_ldd.
3443 (ldd_address_operand): New.
3444 * config/frv/frv-protos.h (frv_legitimate_address_p): Adjust.
3445 * config/frv/frv.h (GO_IF_LEGITIMATE_ADDRESS): Likewise.
3446 (PREDICATE_CODES): Add ldd_address_operand.
3447 * config/frv/frv.md (movdi_ldd): New.
3448 (symGOT2reg_hilo, symGOTOFF2reg_hilo): Use separate pseudo for
3449 intermediate computations if possible.
3450 (symGOTOFF2reg_i): Fix harmless typo.
3451 2003-12-18 Alexandre Oliva <aoliva@redhat.com>
3452 * unwind-dw2-fde-glibc.c (_Unwind_IteratePhdrCallback): Cast
3453 relocated p_vaddr to vaddr type.
3454 * config/frv/frv-protos.h (frv_expand_fdpic_call): Return void.
3455 * config/frv/frv.c (frv_get_funcdesc_alias_set): New.
3456 (frv_expand_fdpic_call): Propagate incoming MEM's expr to funcdesc
3457 MEM, or use a funcdesc alias set. Use regular move instead of
3459 (dbl_memory_one_insn_operand): Recognize function descriptors by
3460 type or by alias set, and don't split them.
3461 * config/frv/frv.md (call, call_value): Never use call_internal
3463 (call_internal, call_value_internal): Never match for FDPIC.
3464 (call_fdpicdi, call_fdpicsi, call_value_fdpicdi,
3465 call_value_fdpicsi): Require FDPIC.
3467 2003-12-17 Alexandre Oliva <aoliva@redhat.com>
3468 * config/frv/frv.h (CRT_GET_RFIB_DATA): Define for __FRV_FDPIC__.
3469 * unwind-dw2-fde-glibc.c: Don't include elf-fdpic.h any more.
3470 (_Unwind_IteratePhdrCallback): Adjust type of load_base for FRV
3471 FDPIC. Compute data base address.
3472 * config/frv/linux.h (SUBTARGET_DRIVER_SELF_SPECS): Enable -mfdpic
3473 before the other self-specs are processed.
3474 * config/frv/t-linux (CRTSTUFF_T_CFLAGS, TARGET_LIBGCC2_CFLAGS):
3476 2003-12-15 Alexandre Oliva <aoliva@redhat.com>
3477 * unwind-dw2-fde-glibc.c: Don't include bits/elf-fdpic.h if
3478 inhibit_libc is defined.
3479 2003-12-12 Alexandre Oliva <aoliva@redhat.com>
3480 * unwind-dw2-fde-glibc.c: Include bits/elf-fdpic.h for
3482 (__RELOC_POINTER): Define.
3483 (_Unwind_IteratePhdrCallback): Use it.
3484 * config/frv/frv.h (Twrite): Define.
3485 (TRANSFER_FROM_TRAMPOLINE): Use it.
3486 * config/frv/linux.h (INVOKE__main): Undefine.
3488 2003-12-05 Richard Sandiford <rsandifo@redhat.com>
3489 * doc/invoke.texi (-mlong-calls, -mlinked-fp): Document FRV options.
3490 (-mlibrary-pic): Emphasize that this option generates EABI code.
3493 2003-11-30 Alexandre Oliva <aoliva@redhat.com>
3494 * config/frv/frv.c (int_2word_operand): Reject LABELs, SYMBOL_REFs
3495 and CONSTs in FDPIC mode.
3496 * gcc/config.gcc (with_cpu): Default to fr400 on frv-*-*linux*.
3497 2003-11-29 Richard Sandiford <rsandifo@redhat.com>
3498 * config/frv/frv.c (move_source_operand): Don't accept symbolic
3500 * config/frv/frv.md (*movhi_internal, *movsi_internal): Use an 'n'
3501 rather than 'i' constraint for the 2-instruction alternative.
3502 (*movsi_2word): New, incorporating existing int_2word_operand splitter.
3503 2003-11-29 Richard Sandiford <rsandifo@redhat.com>
3504 * config/frv/frv.h (EXTRA_CONSTRAINT_FOR_Q): Renamed from
3505 EXTRA_CONSTRAINT_FOR_Y.
3506 (EXTRA_CONSTRAINT): Remove handling of 'Y'.
3507 * config/frv/frv.md (*movsi_internal): Remove 'Q' constraint.
3508 (addsi3): Change 'Y' constraint to 'Q'.
3509 2003-11-27 Richard Sandiford <rsandifo@redhat.com>
3510 * reload.c (CONST_POOL_OK_P): New macro.
3511 (find_reloads): Use it to decide whether a constant can be forced
3513 * config/frv/frv.h (LEGITIMATE_PIC_OPERAND_P): Return true if the
3514 constant satisfies got12_operand.
3515 (frv_cannot_force_const_mem): Always return true for TARGET_FDPIC.
3516 (frv_legitimate_address_p): Check for valid unspec offsets using
3517 got12_operand rather than frv_legitimate_fdpic_operand_p.
3518 (frv_legitimate_fdpic_operand_p): Delete.
3519 (frv_emit_movsi): Abort if we try to use the FDPIC register during
3521 (frv_legitimate_constant_p): Return LEGITIMATE_PIC_OPERAND_P if
3523 * config/frv/frv.md (*movdf_double): Add alternatives for CONST_DOUBLE.
3524 2003-11-19 Richard Sandiford <rsandifo@redhat.com>
3525 * config/frv/frv-protos.h (fdpic_operand, fdpic_got12_operand)
3526 (frv_fdpic_fptr_operand): Don't declare here.
3527 * config/frv/frv.h (EXTRA_CONSTRAINT_FOR_Y): Call got12_operand
3528 rather than fdpic_got12_operand.
3529 (PREDICATE_CODES): Remove symbolic_operand entry. Add entries for
3530 got12_operand and const_unspec_operand.
3531 * config/frv/frv.c (got12_operand): Renamed from fdpic_got12_operand.
3532 (gpr_or_int12_operand, dbl_memory_one_insn_operand): Update calls.
3533 (symbolic_operand): Remove.
3534 (const_unspec_operand): New predicate.
3535 * config/frv/frv.md (*movsi_got): Use got12_operand.
3536 (*movsi_high_got, *movsi_lo_sum_got): Use const_unspec_operand.
3537 2003-11-18 Richard Sandiford <rsandifo@redhat.com>
3538 * config/frv/frv-protos.h (frv_output_addr_const_extra): Remove.
3539 * config/frv/frv.h (OUTPUT_ADDR_CONST_EXTRA): Remove definition.
3540 * config/frv/frv.c (frv_unspec): New structure.
3541 (frv_small_data_reloc_p, frv_const_unspec_p): New functions.
3542 (frv_print_operand_memory_reference): Use frv_const_unspec_p to
3543 validate CONST indices. Use frv_output_const_unspec to print them.
3544 (frv_print_operand): Update call to unspec_got_name. Use
3545 frv_output_const_unspec to print constant unspecs.
3546 (frv_legitimate_fdpic_operand_p): Return true if frv_const_unspec_p.
3547 Reject UNSPECs otherwise.
3548 (unspec_got_name): Take the relocation number as argument, not an
3550 (frv_output_addr_const_extra): Remove, replacing with...
3551 (frv_output_const_unspec): ...this new function.
3552 (frv_find_base_term): Use frv_const_unspec_p & frv_small_data_reloc_p.
3553 (gpr_or_int12_operand): Use fdpic_got12_operand.
3554 (dbl_memory_one_insn_operand): Likewise.
3555 (fdpic_got12_operand): Use frv_const_unspec_p.
3556 (frv_emit_movsi): Use frv_const_unspec_p to check for CONSTs that
3557 are already legitimate. Use frv_small_data_reloc_p when deciding
3558 whether to use HIGH/LO_SUM for R_FRV_GOTOFF12 and R_FRV_GPREL12.
3559 2003-11-18 Alexandre Oliva <aoliva@redhat.com>
3560 * config/frv/t-linux (SHLIB_MAPFILES): Override so as to export...
3561 * config/frv/libgcc-frv.ver: ... frv-specific symbols. New file.
3562 * config/frv/frv-abi.h (CREATE_DOUBLE_SHIFT): Use branch to local
3563 label, for real this time.
3564 * config/frv/frv.c (frv_local_funcdesc_p): Update to new
3565 representation of visibility.
3566 (fdpic_got12_operand, symbolic_operand): Mark unused arguments as
3568 2003-11-17 Richard Sandiford <rsandifo@redhat.com>
3569 * config/frv/frv.h (MASK_LINKED_FP, TARGET_LINKED_FP): New macros.
3570 (TARGET_SWITCHES): Add -mlinked-fp and -mno-linked-fp.
3571 * config/frv/frv.c (frv_override_options): Set MASK_LINKED_FP unless
3572 it was explicitly disabled.
3573 (frv_stack_info): There is no need to save the link register in every
3574 frame unless TARGET_LINKED_FP is true.
3575 (frv_frame_pointer_required): If !TARGET_LINKED_FP, only require a
3576 frame pointer if the stack pointer might change value.
3577 (frv_return_addr_rtx): Check and process "count" argument.
3578 2003-11-14 Richard Sandiford <rsandifo@redhat.com>
3579 * config/frv/frv-protos.h (frv_legitimize_address): Remove.
3580 (frv_find_base_term): Declare.
3581 * config/frv/frv.h (LEGITIMIZE_ADDRESS): Do nothing.
3582 (FIND_BASE_TERM): Define.
3583 (PREDICATE_CODES): Remove pic_register_operand, pic_symbolic_operand,
3584 small_data_register_operand, small_data_symbolic_operand. Add
3586 * config/frv/frv.c (const_small_data_p, plus_small_data_p): Delete.
3587 (frv_print_operand_memory_reference, output_move_single): Remove
3588 special handling for unlegitimized sdata addresses.
3589 (frv_legitimate_address_p): Don't allow sums of SDA_BASE_REG
3590 and symbolic addresses.
3591 (frv_legitimize_address, frv_legitimize_fdpic_address): Delete.
3592 (frv_find_base_term): New function.
3593 (int_2word_operand): Check specifically for symbolic address constants.
3594 (pic_register_operand, pic_symbolic_operand): Delete.
3595 (small_data_register_operand, small_data_symbolic_operand): Delete.
3596 (dbl_memory_one_insn_operand): Don't call plus_small_data_p.
3597 Allow UNSPEC_GOT constants if !TARGET_FDPIC.
3598 (move_source_operand): Only accept CONSTs if they're a two-insn
3600 (fdpic_got12_operand): Don't require TARGET_FDPIC.
3601 (frv_emit_movsi): Legitimize sdata and -mlibrary-pic addresses
3602 using gen_symGOTOFF2reg*.
3603 (frv_ifcvt_rewrite_mem): Remove (plus gr16 ...) special cases.
3604 (frv_rtx_costs): Give all MEM addresses a cost of 0. Give MEMs
3605 themselves a cost of 3 insns.
3606 * config/mips/mips.md (*movsi_got): Allow for !TARGET_FDPIC too.
3607 Change predicate to symbolic_operand.
3608 (*movsi_high_got, *movsi_lo_sum_got): Likewise.
3609 (*movsi_lda_sdata): Delete.
3610 (*movsi_pic, movsi_high_pic, movsi_lo_sum_pic): Delete.
3611 2003-11-05 Alexandre Oliva <aoliva@redhat.com>
3612 * config.gcc: Add t-slibgcc-elf-ver and support --with-cpu for
3614 * config/frv/frv-abi.h (CREATE_DOUBLE_SHIFT): Use branch to local
3616 * config/frv/frv.h (DRIVER_SELF_SPECS): Add blank before
3617 -multilib-library-pic.
3618 (LINK_SPEC): Add -z text for -mfdpic.
3619 * config/frv/frvbegin.c (__ROFIXUP_LIST__): Don't define on FDPIC.
3620 * config/frv/frvend.c (__ROFIXUP_END__): Likewise.
3621 * config/frv/linux.h (STARTFILE_SPEC, ENDFILE_SPEC, LINK_SPEC):
3623 (OPTION_DEFAULT_SPECS, HAS_INIT_SECTION, INIT_SECTION_ASM_OP,
3624 FINI_SECTION_ASM_OP, CRT_CALL_STATIC_FUNCTION): Define.
3625 * config/frv/t-linux (EXTRA_MULTILIB_PARTS): Use
3626 crtstuff-generated files.
3627 2003-10-31 Alexandre Oliva <aoliva@redhat.com>
3628 * config.gcc: Add frv-*-*linux*.
3629 * config/frv/linux.h, config/frv/t-linux: New.
3630 2003-10-06 Alexandre Oliva <aoliva@redhat.com>
3631 * config/frv/frv.h (LINK_SPEC): Pass -melf32frvfd to the linker
3632 when -mfdpic even if a linker script is explicitly listed.
3633 2003-10-02 Alexandre Oliva <aoliva@redhat.com>
3634 * config/frv/frv.c (frv_override_options): Clear asm_out
3635 unaligned_op for SImode on FDPIC.
3636 (frv_emit_movsi): Use compute_reloc_for_constant to compute the
3637 argument passed to decl_readonly_section.
3638 (frv_assemble_integer): Revert 2003-09-30's change, but make the
3639 whole block run with FDPIC even with -fno-PIC.
3640 2003-10-02 Alexandre Oliva <aoliva@redhat.com>
3641 * config/frv/frv.c (frv_cannot_force_const_mem): Don't force
3642 symbol or label plus offset to memory.
3643 (frv_emit_movsi): Emit GPREL only if -mgprel-ro. Emit 32-bit
3644 GOTOFF and GPREL for LABEL_REF.
3645 * config/frv/frv.h (DRIVER_SELF_SPECS): Add -mgprel-ro with
3646 -mfdpic unless -mno-gprel-ro, -fpic or -fpie.
3647 (MASK_GPREL_RO, TARGET_GPREL_RO): New.
3648 (TARGET_SWITCHES): Added gprel-ro and no-gprel-ro.
3649 * doc/invoke.texi: Document them.
3650 2003-09-30 Alexandre Oliva <aoliva@redhat.com>
3651 * config/frv/frv-protos.h (frv_gen_GPsym2reg): Declare.
3652 (frv_splittable_got_operand): Removed.
3653 * config/frv/frv.c (frv_cannot_force_const_mem): Reject HIGH and
3654 LO_SUM. Add comments.
3655 (frv_override_options): Moved enabling of FDPIC to
3656 DRIVER_SELF_SPECS. Don't enable MASK_DWORD.
3657 (frv_local_funcdesc_p): Remove unnecessary heck for flag_pie.
3658 (frv_legitimize_fdpic_address): Don't duplicate logic in
3660 (frv_gen_GPsym2reg): New.
3661 (unspec_got_name): Added gprel.
3662 (frv_expand_fdpic_call): Add support for inlining PLTs.
3663 (fdpic_fptr_operand): Renamed from frv_fdpic_fptr_operand.
3664 (gpr_or_int12_operand): Added GPREL12.
3665 (pic_symbolic_operand): Match even if !flag_pic for FDPIC.
3666 (small_data_symbolic_operand): Fail if FDPIC.
3667 (fdpic_splittable_got_operand): Removed.
3668 (fdpic_got12_operand): Added GPREL12.
3669 (frv_emit_movsi): Reorganize to avoid duplication. Emit GPREL
3670 when appropriate. Fix sdata GOTOFF.
3671 (frv_legitimate_constant_p): Require legitimate PIC operand for
3672 FDPIC with pic, but only a legitimate fdpic operand for non-pic.
3673 (frv_assemble_integer): Move FDPIC funcdesc handling out of
3675 (frv_asm_out_constructor, frv_asm_out_destructor): Abort if
3676 frv_assemble_integer fails.
3677 * config/frv/frv.h (DRIVER_SELF_SPECS): New.
3678 (SUBTARGET_DRIVER_SELF_SPECS): New.
3679 (ASM_SPEC): Don't pass -mno-fdpic.
3680 (LINK_SPEC): Pass -melf32frvfd for FDPIC.
3681 (MASK_INLINE_PLT, TARGET_INLINE_PLT): New.
3682 (TARGET_SWITCHES): Add -minline-plt, -mno-inline-plt and
3683 -multilib-library-pic.
3684 (PREDICATE_CODES): Added fdpic_operand, fdpic_fptr_operand,
3685 condexec_si_media_operator, condexec_sf_add_operator and
3686 condexec_sf_conv_operator. Removed condexec_sf_binary_operator
3687 and condexec_sf_unary_operator.
3688 * config/frv/frv.md (R_FRV_GPREL12, R_FRV_GPRELHI, R_FRV_GPRELLO):
3690 (movsi_got, movsi_high_got, movsi_lo_sum_got): Move before
3691 movsi_internal. Give them internal names. movsi_got has type
3693 (fdpic got splitters): Remove.
3694 (symGPREL2reg, symGPREL2reg_hilo): New.
3695 * config/frv/t-frv (MULTILIB_MATCHES): Don't map -fpic and -fPIC
3696 to -mlibrary-pic. Map -multilib-library-pic to it.
3697 * doc/invoke.texi: -mfdpic, -minline-plt, -multilib-library-pic:
3699 2003-09-28 Alexandre Oliva <aoliva@redhat.com>
3700 * config/frv/frv.c (frv_function_symbol_referenced_p): Declare.
3701 (TARGET_CANNOT_FORCE_CONST_MEM): Define to...
3702 (frv_cannot_force_const_mem): New function.
3703 (const_small_data_p, plus_small_data_p): Update comments on sdata
3705 (frv_override_options): Set flag_pie for FDPIC too.
3706 (frv_conditional_register_usage): Mark gr16 and gr17 as non-fixed,
3707 call-saved registers on FDPIC.
3708 (frv_stack_info): Don't preserve the PIC register on FDPIC, and
3709 don't force LR to be preserved.
3710 (frv_expand_prologue): Likewise.
3711 (frv_asm_output_mi_thunk): Use 12-bit funcdesc gotoff for -fpic.
3712 (frv_frame_pointer_required): Don't force it just because the
3713 FDPIC register is used.
3714 (frv_legitimate_address_p) <CONST>: Accept a legitimate FDPIC
3715 operand only if !condexec_p.
3716 (frv_legitimize_address): Return the FDPIC-legitimized address.
3717 Don't match small data here on FDPIC.
3718 (frv_legitimate_fdpic_operand_p): Don't accept unadorned function
3719 symbols. Use TRUE/FALSE instead of 1/0.
3720 (frv_local_funcdesc_p): New.
3721 (frv_legitimize_fdpic_address): Rewrite to use GOTOFF and 12-bit
3722 immediates when possible.
3723 (pic_symbolic_operand): Accept SYMBOL_REFs and CONSTs in FDPIC.
3724 (dbl_memory_one_insn_operand): Accept addresses that add a REG and
3726 (frv_emit_movsi): Handle FDPIC before small data. Use GOTOFF and
3727 12-bit immediates when possible.
3728 (frv_legitimate_constant_p): In FDPIC, reject SImode operands that
3729 are not legitimate pic operands.
3730 (frv_in_small_data_p): Re-enable for FDPIC.
3731 * config/frv/frv.h (SDA_BASE_REG): Remove comment about FDPIC.
3732 (FRV_GLOBAL_P): Removed.
3733 * config/frv/frv.md: Add modes to CONSTs.
3735 (movsi_lo_sum_got): Use separate matches instead of match_dup.
3736 (movsi_high_pic, movsi_lo_sum_pic): Match on non-FDPIC only.
3737 (fdpic splittable operations): Match on flag_pic != 1.
3738 2003-09-22 Alexandre Oliva <aoliva@redhat.com>
3739 * config/frv/frv.c (frv_asm_out_constructor,
3740 frv_asm_out_destructor): Pass to frv_assemble_integer the size in
3742 2003-09-19 Alexandre Oliva <aoliva@redhat.com>
3743 * config/frv/frv.c (frv_assemble_integer): Reject complex
3744 expressions referencing function SYMBOL_REFs.
3745 * config/frv/frv.c (frv_function_symbol_referenced_p): New.
3746 (move_source_operand): Reject CONSTs that reference function
3747 SYMBOL_REFs on FDPIC.
3748 (frv_emit_movsi): If we get such a CONST, break it up.
3749 * config/frv/frv.h (CPP_SPEC): Define __FRV_FDPIC__ for -mfdpic.
3750 (TRANSFER_FROM_TRAMPOLINE): Use different definitions for FDPIC.
3751 * config/frv/frv.c (frv_print_operand) <I>: Recognize PLUS without
3753 (frv_assemble_integer): Don't use funcdesc for LABEL_REFs.
3754 (frv_trampoline_size): Increase for FDPIC.
3755 * config/frv/frv.h (TRAMPOLINE_ALIGNMENT): Bump to 64 for FDPIC.
3756 (TRANSFER_FROM_TRAMPOLINE): Handle FDPIC trampolines.
3757 * config/frv/frv.c (frv_legitimize_fdpic_address, frv_emit_movsi):
3758 Disable use of GOTOFF for now.
3759 (const_small_data_p, plus_small_data_p, frv_in_small_data_p):
3760 Disable use of small data in FDPIC for now.
3761 (frv_asm_output_mi_thunk): Implement for FDPIC.
3762 * config/frv/frv.h (SDA_BASE_REG): Set to -1 with FDPIC.
3763 * config/frv/frv.c (frv_asm_out_constructor): Use
3764 frv_assemble_integer for FDPIC pointers.
3765 (frv_asm_out_destructor): Likewise.
3766 * config/frv/frv.md (ldd): Fix order of operands. Use
3767 address_operand for input.
3768 2003-09-18 DJ Delorie <dj@redhat.com>
3769 * config/frv/frv.c (frv_legitimate_fdpic_operand_p): Remove UNSPEC_PIC.
3770 (unspec_got_name): Correct typo.
3771 (frv_emit_movsi): Pre-expand splittable GOTs.
3772 (frv_expand_fdpic_call): Rename gen_lddi to gen_ldd.
3773 * config/frv/frv.md (lddi): Fix syntax error, rename to ldd.
3774 (symGOT2reg_hilo, symGOTOFF2reg_hilo): New.
3775 * config/frv/t-frv: Add -mfdpic multilibs.
3776 * config/frv/frv.h (ASM_SPEC): Pass -mfdpic/-mno-fdpic.
3777 (TARGET_SWITCHES): Add -mno-fdpic, fix documentation.
3778 * config/frv/frv.c (frv_override_options): -mfdpic assumes
3779 flag_pic, default to 32-bit pics, require DWORD ops.
3780 (frv_override_options): Add W and Z constraints.
3781 (frv_expand_prologue): No pic prologue for -mfdpic.
3782 (frv_asm_output_mi_thunk): Support -mfdpic (soon).
3783 (frv_print_operand_memory_reference): Handle GOT constants.
3784 (frv_legitimate_address_p): Allow GOT constants.
3785 (frv_legitimize_address): Handle GOT addresses too.
3786 (frv_legitimate_fdpic_operand_p): New.
3787 (frv_legitimize_fdpic_address): New.
3788 (unspec_got_name): New.
3789 (frv_output_addr_const_extra): New.
3790 (frv_expand_fdpic_call): New.
3791 (frv_fdpic_fptr_operand): New.
3792 (gpr_or_int12_operand): Handle GOT operands.
3793 (int_2word_operand): Handle GOT operands.
3794 (fdpic_operand): New.
3795 (fdpic_splittable_got_operand): New.
3796 (fdpic_got12_operand): New.
3797 (frv_emit_movsi): Handle GOT operands.
3798 (frv_assemble_integer): -mfdpic doesn't use rofixups.
3799 (frv_print_operand): Support 'g' code for GOT operands.
3800 * config/frv/frv-protos.h: Add prototypes as needed.
3801 * config/frv/frv.md (R_FRV_GOT12, R_FRV_GOTHI, R_FRV_GOTLO,
3802 R_FRV_FUNCDESC, R_FRV_FUNCDESC_GOT12, R_FRV_FUNCDESC_GOTHI,
3803 R_FRV_FUNCDESC_GOTLO, R_FRV_FUNCDESC_VALUE,
3804 R_FRV_FUNCDESC_GOTOFF12, R_FRV_FUNCDESC_GOTOFFHI,
3805 R_FRV_FUNCDESC_GOTOFFLO, R_FRV_GOTOFF12, R_FRV_GOTOFFHI,
3806 R_FRV_GOTOFFLO): New.
3807 (movsi_high_got, movsi_lo_sum_got): New.
3808 (*movsi_pic): Don't use this splitter for -mfdpic.
3809 (addsi3): Allow GOT references also.
3810 (call, call_value): Handle -mfdpic separately.
3811 (call_fdpicdi, call_fdpicsi, lddi, call_value_fdpicdi,
3812 call_value_fdpicsi): New.
3813 (symGOT2reg, symGOT2reg_i, got splitters, symGOTOFF2reg,
3814 symGOTOFF2reg_i): New.
3815 * config/frv/frv.h (MASK_FDPIC): New.
3816 (TARGET_FDPIC): New.
3817 (TARGET_SWITCHES): Add -mfdpic.
3818 (FDPIC_FPTR_REGNO): New.
3820 (OUR_FDPIC_REG): New.
3821 (enum reg_class): Add FDPIC_REGS, FDPIC_FPTR_REGS, and
3823 (REG_CLASS_NAMES): Likewise.
3824 (REG_CLASS_CONTENTS): Likewise.
3825 (EXTRA_CONSTRAINT_FOR_Y): New, for 12-bit GOTs.
3826 (EXTRA_CONSTRAINT): Add it here.
3827 (FRV_GLOBAL_P): New.
3828 (OUTPUT_ADDR_CONST_EXTRA): New.
3830 2004-02-24 Kazu Hirata <kazu@cs.umass.edu>
3832 * config/sparc/sparc.h: Remove commented-out definitions of
3833 TARGET_EDOM and GEN_ERRNO_RTX.
3835 2004-02-24 Kazu Hirata <kazu@cs.umass.edu>
3837 * df.c, df.h, ra-build.c, ra-rewrite.c, ra.c, web.c: Replace
3838 df_analyse with df_analyze.
3840 2004-02-24 Alan Modra <amodra@bigpond.net.au>
3842 * gcse.c (delete_null_pointer_checks_1): Set stop_insn to end, not
3845 2004-02-23 James E Wilson <wilson@specifixinc.com>
3847 * calls.c (precompute_arguments): Update comment.
3849 2004-02-23 Kazu Hirata <kazu@cs.umass.edu>
3851 * et-forest.c: Replace et_occurences with et_occurrences.
3853 2004-02-23 Kazu Hirata <kazu@cs.umass.edu>
3855 * cfgloop.h, loop-iv.c, loop-unswitch.c: Replace iv_analyse
3858 2004-02-23 Kelley Cook <kcook@gcc.gnu.org>
3860 * config/i386/i386.c: Rename pni to sse3.
3861 * config/i386/i386.h: Likewise.
3862 * config/i386/i386.md: Likewise.
3863 * config/i386/pmmintrin.h: Likewise.
3864 * doc/extend.texi: Likewise.
3865 * doc/invoke.texi: Likewise.
3867 2004-02-23 Zack Weinberg <zack@codesourcery.com>
3868 Kazu Hirata <kazu@cs.umass.edu>
3870 Remove -fwritable-strings.
3871 * c-common.c (fix_string_type): Don't check
3872 flag_writable_strings.
3873 (fix_string_type): Likewise.
3874 * c-opts.c (set_std_c89): Don't initialize
3875 flag_writable_strings.
3876 (set_std_c99): Likewise.
3877 * common.opt (fwritable-strings): Remove.
3878 * flags.h: Remove the external declaration of
3879 flag_writable_strings.
3880 * opts.c (common_handle_option) <OPT_fwritable_strings>:
3882 * toplev.c (flag_writable_strings): Remove.
3883 (f_options): Remove an entry for writable-strings.
3884 * varasm.c (const_hash_1) <STRING_CST>: Don't check
3885 flag_writable_strings.
3886 (compare_constant) <STRING_CST>: Likewise.
3887 (build_constant_desc): Likewise.
3888 * config/darwin.c (machopic_select_section): Likewise.
3889 * config/arm/arm.c (AOF_ASSEMBLER): Likewise.
3890 * config/arm/pe.c (arm_pe_encode_section_info): Likewise.
3891 * config/iq2000/iq2000.c (iq2000_select_section): Likewise.
3892 * config/mips/mips.c (mips_select_section): Likewise.
3893 (mips_encode_section_info): Likewise.
3894 * config/pa/pa.c (pa_select_section): Likewise.
3895 * config/pa/pa.h (TEXT_SPACE_P): Likewise.
3896 * config/v850/v850.c (v850_select_section): Likewise.
3897 * doc/invoke.texi (-fwritable-strings): Remove.
3898 (-fno-const-strings): Don't mention -fwritable-strings.
3899 * doc/trouble.texi: Don't mention -fwritable-strings.
3901 2003-02-23 Nathanael Nerode <neroden@gcc.gnu.org>
3903 * doc/install.texi: Update for switch of boehm-gc to autoconf 2.57.
3905 2004-02-23 Dale Johannesen <dalej@apple.com>
3907 * config/rs6000.md (movsf_hardfloat): Add POWER form of nop.
3908 (movdf_hardfloat64): Ditto.
3909 (movdf_softfloat64): Ditto.
3911 2004-02-23 Fariborz Jahanian <fjahanian@apple.com>
3912 * config/rs6000/rs6000.c (function_arg): call to
3913 rs6000_mixed_function_arg for DFmode moved to allow
3914 normal DFmode incoming register assignment.
3916 2004-02-23 Dale Johannesen <dalej@apple.com>
3918 * config/rs6000.md (movsf_hardfloat): Accept CTR-to-CTR copy.
3919 (movdf_hardfloat64): Ditto.
3921 2004-02-23 Kazu Hirata <kazu@cs.umass.edu>
3923 * convert.c, gcov-io.c, libgcov.c, sched-int.h, sibcall.c,
3924 config/rs6000/linux.h, config/rs6000/rs6000-c.c: Update
3927 2004-02-23 Andrew Pinski <pinskia@physics.uc.edu>
3930 * c-typeck.c (c_expand_return): Change check for VAR_DECL
3931 to use DECL_P instead.
3933 * config/rs6000/linux.h (OS_MISSING_POWERPC64): Define.
3934 * config/rs6000/linux64.h (OS_MISSING_POWERPC64): Define.
3936 2004-02-23 Kazu Hirata <kazu@cs.umass.edu>
3938 * Makefile.in (opts.o): Depend on target.h.
3939 * opts.c (decode_options): Use targetm.default_short_enums
3940 instead of DEFAULT_SHORT_ENUMS.
3941 * system.h (DEFAULT_SHORT_ENUMS): Poison.
3942 * target-def.h (TARGET_DEFAULT_SHORT_ENUMS): New.
3943 (TARGET_INITIALIZER): Add TARGET_DEFAULT_SHORT_ENUMS.
3944 * target.h (gcc_target): Add default_short_enums.
3945 * config/cris/cris.h: Remove a comment about
3946 DEFAULT_SHORT_ENUMS.
3947 * config/ip2k/ip2k.h: Likewise.
3948 * doc/tm.texi (DEFAULT_SHORT_ENUMS): Change to
3949 TARGET_DEFAULT_SHORT_ENUMS. Update the description.
3951 2004-02-23 Eric Botcazou <ebotcazou@libertysurf.fr>
3952 Falk Hueffner <falk@debian.org>
3955 * builtins.c (expand_builtin_va_arg): Emit an informative message
3956 if a trap is generated.
3957 * c-typeck.c (build_function_call): Likewise.
3959 2004-02-22 Jakub Jelinek <jakub@redhat.com>
3961 * gcov-io.c (gcov_open) [GCOV_LOCKED]: Use open + fdopen instead of
3963 * libgcov.c: Include sys/stat.h.
3964 * config/rs6000/linux.h (TARGET_HAS_F_SETLKW): Define.
3965 * config/rs6000/linux64.h (TARGET_HAS_F_SETLKW): Define.
3966 * config/sparc/linux.h (TARGET_HAS_F_SETLKW): Define.
3967 * config/sparc/linux64.h (TARGET_HAS_F_SETLKW): Define.
3969 2004-02-22 Kazu Hirata <kazu@cs.umass.edu>
3971 * reorg.c: Remove comments about dead ports.
3973 2004-02-22 Christopher Faylor <cgf@redhat.com>
3975 * config.gcc (i[34567]86-*-pe|i[34567]86-*-cygwin*): *Really* specify
3976 extra host object file when targetting cygwin rather than generic
3979 2004-02-22 Josef Zlomek <zlomekj@suse.cz>
3981 Merge from tree-ssa:
3982 2003-11-20 Richard Henderson <rth@redhat.com>
3984 * tree-inline.c (insert_decl_map): New.
3985 (remap_decl, remap_type, remap_block, copy_body_r,
3986 initialize_inlined_parameters, declare_return_variable,
3987 remap_save_expr): Use it.
3989 * function.c (copy_body_r): Add mapping from id->ret_label to
3990 id->ret_label. Revert test for ret_label.
3992 2004-02-22 Jakub Jelinek <jakub@redhat.com>
3994 * genoutput.c (process_template): Strip trailing whitespace in @
3995 templates and issue a warning if there was any.
3997 2004-02-21 Christopher Faylor <cgf@redhat.com>
3999 * config.gcc (i[34567]86-*-pe|i[34567]86-*-cygwin*): Specify extra host
4000 object file when targetting cygwin.
4001 * config/i386/t-cygwin (EXTRA_GCC_OBJS): Remove definition since it is
4002 overridden by top-level Makefile.
4004 2004-02-21 Roger Sayle <roger@eyesopen.com>
4006 * config/i386/i386.c (standard_80387_constant_p): Also prefer
4007 the x87's load constant instructions when optimizing for size.
4009 2004-02-21 Kazu Hirata <kazu@cs.umass.edu>
4011 * combine.c (SHIFT_COUNT_TRUNCATED): Remove.
4012 * defaults.h (SHIFT_COUNT_TRUNCATED): Provide the default.
4013 * expmed.c: Assume SHIFT_COUNT_TRUNCATED is always defined.
4014 * fold-const.c: Likewise.
4015 * simplify-rtx.c: Likewise.
4017 2004-02-21 Alan Modra <amodra@bigpond.net.au>
4019 * combine.c (can_combine_p): Don't ignore SETs marked with
4020 REG_EH_REGION notes.
4021 (try_combine): When attemting to fix unrecognized insns, don't
4022 split a PARALLEL that contains the original i2.
4024 2004-02-21 Ziemowit Laski <zlaski@apple.com>
4026 * config/darwin.h (TARGET_OPTION_TRANSLATE_TABLE): Refer to
4027 SUBTARGET_OPTION_TRANSLATE_TABLE for architecture-specific options.
4028 * config/i386/darwin.h (SUBTARGET_OPTION_TRANSLATE_TABLE): Define it.
4029 * config/rs6000/altivec.h: #error out if '-maltivec' not specified.
4030 (vector, pixel, bool): #define to __vector, __pixel and __bool.
4031 (__un_args_eq, __bin_args_eq, __tern_args_eq): Move to C-specific
4033 (__altivec_link_error_invalid_argument): Remove prototype; will use
4034 __builtin_altivec_compiletime_error("vec_*") instead.
4035 (vec_*): Fix/complete set of available operation overloads given the
4036 existence of distinct 'vector bool ...' and 'vector pixel' types; tighten
4037 cv-correctness of pointer arguments; in C, always check for correct
4038 argument types before macro expansion.
4039 * config/rs6000/darwin.h (SUBTARGET_OPTION_TRANSLATE_TABLE): New macro
4040 defining Darwin/PowerPC-specific '-f[no-]altivec' and
4041 '-W[no-]altivec-long-deprecated' switches.
4042 * config/rs6000/rs6000-c (rs6000_cpu_cpp_builtins): Pre-define
4043 '__vector', '__pixel' and '__bool' macros using
4044 '__attribute__((altivec(...)))' types.
4045 * config/rs6000/rs6000.c (bool_char_type_node, bool_short_type_node,
4046 bool_int_type_node, pixel_type_node, bool_V16QI_type_node,
4047 bool_V8HI_type_node, bool_V4SI_type_node, pixel_V8HI_type_node):
4049 (rs6000_warn_altivec_long, rs6000_warn_altivec_long_switch): New, for
4050 handling '-W[no-]altivec-long-deprecated'.
4051 (rs6000_override_options): Handle '-W[no-]altivec-long-deprecated'.
4052 (rs6000_expand_binop_builtin, rs6000_expand_ternop_builtin,
4053 altivec_expand_dst_builtin): Remove casts from integer literals.
4054 (altivec_expand_builtin): Likewise; handle expansion of new
4055 '__builtin_altivec_compiletime_error' function.
4056 (rs6000_init_builtins): Initialize 'vector bool ...' and 'vector pixel'
4057 types, and make them distinct from other vector types; register
4058 '__builtin_altivec_compiletime_error' function.
4059 (print_operand): For 'P', print a full target register name instead of
4061 (rs6000_attribute_table): Add "altivec" attribute.
4062 (rs6000_handle_altivec_attribute): New function.
4063 * config/rs6000/rs6000.h (TARGET_OPTIONS): Describe
4064 '-m[no-]-warn-altivec-long' (which '-W[no-]altivec-long-deprecated'
4066 (rs6000_warn_altivec_long, rs6000_warn_altivec_long_switch): Forward
4068 (ALTIVEC_BUILTIN_COMPILETIME_ERROR): New built-in enumeration.
4070 2004-02-20 James E Wilson <wilson@specifixinc.com>
4072 * config/ia64/ia64.md (shift_mix4left+1): Delete reload_completed
4074 (shift_mix4left+2): Delete redundant pattern.
4076 2004-02-20 Kazu Hirata <kazu@cs.umass.edu>
4078 * alias.c (OUTGOING_REGNO): Don't define the default.
4079 * builtins.c (OUTGOING_REGNO): Likewise.
4080 (INCOMING_REGNO): Likewise.
4081 (apply_args_register_offset): Always use OUTGOING_REGNO.
4082 * combine.c (OUTGOING_REGNO): Likewise.
4083 * sibcall.c (OUTGOING_REGNO): Likewise.
4084 * defaults.h (INCOMING_REGNO): Provide the default.
4085 (OUTGOING_REGNO): Likewise.
4087 2004-02-21 Jan Hubicka <jh@suse.cz>
4089 * params.def (max-peeled-insns, max-completely-peeled-insns,
4090 max-once-peeled-insns): Set to 400.
4092 2004-02-20 John David Anglin <dave.anglin@nrc-cnrc.gc.ca>
4095 * dbxout.c (dbxout_parms): Check that DECL_RTL and DECL_INCOMING_RTL
4096 are set for parameters before outputing debugging information.
4098 2004-02-20 Falk Hueffner <falk@debian.org>
4101 * config/alpha/alpha.md (*fix_truncsfsi_ieee): Fix typoed operand
4104 2004-02-20 Per Bothner <per@bothner.com>
4106 * input.h: Don't #include line-map.h. It may cause link problems
4107 with undefined linemap_line_start when line-map.h is included but
4108 line-map.o is not linked, as currently happens with gengtype on
4109 compilers that don't support inline.
4110 * toplev.c: So we do have to explicitly #include line-map.h here.
4112 2004-02-20 Richard Henderson <rth@redhat.com>
4114 * doc/invoke.texi: Add -Wvariadic-macros.
4116 2004-02-20 Kazu Hirata <kazu@cs.umass.edu>
4118 * haifa-sched.c (sched_emit_insn): Remove.
4119 * sched-int.h: Remove the corresponding prototype.
4121 2004-02-20 Kazu Hirata <kazu@cs.umass.edu>
4124 2004-02-19 Kazu Hirata <kazu@cs.umass.edu>
4125 * opts.c (decode_options): Don't use DEFAULT_SHORT_ENUMS.
4126 * system.h (DEFAULT_SHORT_ENUMS): Poison.
4127 * config/cris/cris.h: Remove a comment about
4128 DEFAULT_SHORT_ENUMS.
4129 * config/ip2k/ip2k.h: Likewise.
4130 * doc/tm.texi (DEFAULT_SHORT_ENUMS): Remove.
4132 2004-02-20 Mohan Embar <gnustuff@thisiscool.com>
4133 Tom Tromey <tromey@redhat.com>
4135 * doc/install.texi: Moved --disable-libgcj and
4136 --with-system-zlib documentation to new section for
4137 Java-specific options.
4138 Added explicit Cross-Compiler-Specific Options subheading.
4139 Added section for Java-specific options.
4141 2004-02-20 Matt Kraai <kraai@alumni.cmu.edu>
4143 * doc/install.texi (Building the Ada compiler): Remove
4146 2004-02-20 James E Wilson <wilson@specifixinc.com>
4148 * toplev.c (dump_file_index, dump_file): Put ce3 before rnreg.
4150 2004-02-20 Kazu Hirata <kazu@cs.umass.edu>
4152 * gcc.c (process_command): Allow translation of the copyright
4153 symbol but not the rest of the copyright message.
4154 * gcov.c (print_version): Likewise. Allow translation of the
4155 message about warranty.
4157 2004-02-20 Hans-Peter Nilsson <hp@axis.com>
4159 * config/cris/cris.md ("*andsi_movu"): Correct parentheses in
4161 ("*andsi_clear"): Tweak constraints to not match postincrement.
4162 Adjust the predicate to exclude a volatile memory reference.
4163 ("*andhi_clear"): Ditto. Rename from "*andhi_clear_signed".
4164 ("*andhi_clear_unsigned"): Remove, non-matching pattern.
4166 2004-02-19 Matt Kraai <kraai@alumni.cmu.edu>
4168 * move-if-change: Remove.
4169 * Makefile.in (s-mlib, c-parse.y, s-check, s-gencheck)
4170 (s-specs, s-options, s-config, s-conditions, s-flags, s-codes)
4171 (s-constants, s-emit, s-recog, s-opinit, s-extract, s-peep)
4172 (s-attr, s-attrtab, s-output, s-genrtl, s-modes, s-preds)
4173 (s-gtyp-gen, s-iov): Use the top level move-if-change.
4174 * objc/Make-lang.in (objc/objc-parse.y): Likewise.
4176 2004-02-19 James E Wilson <wilson@specifixinc.com>
4178 * config/i386/i386.md (doloop_end_internal): Use nonimmediate_operand
4179 for operand2. Add condition that requires register_operand operand2
4182 2004-02-19 Richard Sandiford <rsandifo@redhat.com>
4183 Maciej W. Rozycki <macro@ds2.pg.gda.pl>
4185 * config/mips/mips.c (mips_address_insns): Treat BLKmode specially.
4186 * config/mips/mips.md: Expand comment above unaligned loads and stores.
4188 2004-02-19 Richard Henderson <rth@redhat.com>
4190 * Makefile.in (STRICT2_WARN): Add -Wno-variadic-macros.
4191 * tree.c (build0, build1, build2, build3, build4): Split out from...
4192 (build): ... here. Call them.
4193 * tree.h (build, _buildN1, _buildN2, _buildC1, _buildC2): New.
4195 * convert.c (convert_to_integer): Remove extra build argument.
4196 * tree-inline.c (expand_call_inline): Likewise.
4198 2004-02-19 Richard Henderson <rth@redhat.com>
4200 * c-opts.c (warn_variadic_macros): New.
4201 (c_common_handle_option): Set it.
4202 (sanitize_cpp_opts): Copy it to cpp_opts.
4203 * c.opt (Wvariadic-macros): New.
4204 * cpplib.h (struct cpp_options): Add warn_variadic_macros.
4205 * cppinit.c (cpp_create_reader): Initialize it.
4206 * cppmacro.c (parse_params): Check it.
4208 2004-02-19 David Daney <ddaney@avtrex.com>
4210 PR preprocessor/14198
4211 * config/mips/linux.h (TARGET_OS_CPP_BUILTINS): Add
4212 builtin_assert ("machine=mips")
4214 2004-02-19 Kazu Hirata <kazu@cs.umass.edu>
4216 * opts.c (decode_options): Don't use DEFAULT_SHORT_ENUMS.
4217 * system.h (DEFAULT_SHORT_ENUMS): Poison.
4218 * config/cris/cris.h: Remove a comment about
4219 DEFAULT_SHORT_ENUMS.
4220 * config/ip2k/ip2k.h: Likewise.
4221 * doc/tm.texi (DEFAULT_SHORT_ENUMS): Remove.
4223 2004-02-19 Zack Weinberg <zack@codesourcery.com>
4225 * config/ia64/ia64.c (ia64_function_arg): In big-endian mode,
4226 when passing single SFmode quantities in general registers,
4227 put them in the high half.
4229 2004-02-19 Aldy Hernandez <aldyh@redhat.com>
4231 * doc/md.texi (Standard Names): Document additional dependency on
4234 * optabs.c (ftruncify): Remove.
4235 (expand_fix): Manually inline ftruncify above.
4236 (can_fix_p): Add FIXME note.
4238 2004-02-19 Aldy Hernandez <aldyh@redhat.com>
4240 * config/rs6000/spe.md (spe_fixunssfsi2): Rename to
4241 spe_fixuns_truncsfsi2.
4243 * config/rs6000/rs6000.md (fixunssfsi2): Rename to
4246 2004-02-19 Steve Ellcey <sje@cup.hp.com>
4248 * config/ia64/ia64.h (HARD_REGNO_CALLER_SAVE_MODE): New macro.
4249 * testsuite/gcc.dg/20040219-1.c: New test.
4251 2004-02-19 Ulrich Weigand <uweigand@de.ibm.com>
4253 * config/s390/s390.md ("*subdf3_cc", "*subdf3_cconly", "*subsf3_cc",
4254 "*subsf3_cconly"): Subtraction is not commutative.
4256 2004-02-19 Zack Weinberg <zack@codesourcery.com>
4258 * sdbout.c (preinit_symbols, sdbout_initialized): New statics.
4259 (sdbout_symbol): If called before sdbout_init, queue DECL for
4261 (sdbout_init): Set sdbout_initialized true, process decls
4262 queued earlier by sdbout_symbol.
4263 (sdbout_finish): Use size_t for index variable.
4265 2004-02-19 Jeff Law <law@redhat.com>
4267 * fold-const.c (invert_truthvalue): Do not call invert_tree_comparison
4268 for unordered comparison codes.
4270 2004-02-19 Ian Lance Taylor <ian@wasabisystems.com>
4272 * reload1.c (reload): Correct comment.
4273 (scan_paradoxical_subregs): Remove #if 0 and old comment.
4274 * doc/extend.texi (Local Reg Vars): Remove obsolete comment that
4275 register variables are not used by reload.
4277 2004-02-19 Hans-Peter Nilsson <hp@axis.com>
4280 * config/cris/cris.md ("*andsi_movu", "*andhi_movu"): Tweak
4281 constraints to not match postincrement. Adjust the predicate to
4282 exclude a volatile memory reference.
4284 2004-02-19 Kazu Hirata <kazu@cs.umass.edu>
4286 * config/mcore/mcore.h (ASM_OUTPUT_EXTERNAL): Remove.
4288 2004-02-19 Kazu Hirata <kazu@cs.umass.edu>
4290 * hooks.c (hook_void_tree_int): Remove.
4291 (hook_void_constcharptr): Likewise.
4292 (hook_int_void_0): Likewise.
4293 * hooks.h: Remove the prototypes for the above three
4295 * targhooks.c (hook_bool_machine_mode_true): Remove.
4296 * targhooks.h: Remove the prototype for
4297 hook_bool_machine_mode_true.
4299 2004-02-19 Kazu Hirata <kazu@cs.umass.edu>
4301 * emit-rtl.c (subreg_realpart_p): Remove.
4302 (reorder_insns_with_line_notes): Likewise.
4303 (end_full_sequence): Likewise.
4304 * rtl.h: Remove the prototype for the above functions.
4306 2004-02-19 Kazu Hirata <kazu@cs.umass.edu>
4308 * config/arc/arc.h, config/arm/arm.h, config/frv/frv.h,
4309 config/h8300/h8300.h, config/i386/i386.h, config/i860/i860.h,
4310 config/iq2000/iq2000.h, config/m32r/m32r.h,
4311 config/pdp11/pdp11.h, config/sparc/sparc.h,
4312 config/xtensa/xtensa.h: Remove commented-out or useless
4313 definitions of CASE_VECTOR_PC_RELATIVE.
4315 2004-02-19 Kazu Hirata <kazu@cs.umass.edu>
4317 * loop.c (all_sets_invariant_p): Remove.
4319 2004-02-19 Eric Botcazou <ebotcazou@libertysurf.fr>
4322 * config/sparc/sparc.h (NPARM_REGS): Delete.
4323 (BASE_RETURN_VALUE_REG): Likewise.
4324 (BASE_OUTGOING_VALUE_REG): Likewise.
4325 (BASE_PASSING_ARG_REG): Likewise.
4326 (BASE_INCOMING_ARG_REG): Likewise.
4327 * config/sparc/sparc.c (sparc_strict_argument_naming): Test
4328 TARGET_ARCH64, not TARGET_V9.
4329 (function_arg_slotno): Dispatch based on the mode class.
4330 Handle vector modes like floating-point modes.
4331 (function_arg_record_value_1): Handle vector types like
4332 floating-point types.
4333 (function_arg_record_value_2): Likewise.
4334 Calculate regno after mode transformation.
4335 (function_arg): Handle vector modes like floating-point modes.
4336 (function_arg_partial_nregs): Replace NPARM_REGS by SPARC_INT_ARG_MAX.
4337 If ARCH64, do not recheck alignment.
4338 (function_arg_pass_by_reference): Reorder the conditions.
4339 (sparc_return_in_memory): Move after function_arg_padding.
4340 Implement calling conventions for vector modes.
4341 (sparc_struct_value_rtx): Move after sparc_return_in_memory.
4342 (function_value): Move scope of 'regbase'.
4343 Implement calling conventions for vector modes.
4344 (sparc_builtin_saveregs): Replace NPARM_REGS by SPARC_INT_ARG_MAX
4345 and BASE_INCOMING_ARG_REG by SPARC_INCOMING_INT_ARG_FIRST.
4346 (sparc_va_arg): Use function_arg_pass_by_reference to test whether
4347 the argument is passed by reference.
4348 (sparc_type_code): Handle vector types.
4350 2004-02-19 Alan Modra <amodra@bigpond.net.au>
4352 * function.c (assign_parms): When building decl_rtl for
4353 SPLIT_COMPLEX_ARGS, ensure inner modes of concat match outer.
4355 2004-02-19 Olivier Hainque <hainque@act-europe.fr>
4357 * expr.c (is_aligning_offset): Check if we are aligning the
4358 expressions's address over BIGGEST_ALIGNMENT in bytes, not
4361 2003-02-18 Matt Austern <austern@apple.com>
4363 * gcc.c (LIBGCC_SPEC): If REAL_LIBGCC_SPEC is defined, and
4364 LIBGCC_SPEC isn't, set LIBGCC_SPEC to REAL_LIBGCC_SPEC.
4365 (init_gcc_spec): Don't define or call if REAL_LIBGCC_SPEC is
4366 defined. Instead use REAL_LIBGCC_SPEC, unmodifed, as the libgcc
4368 * doc/tm.texi (REAL_LIBGCC_SPEC): Document.
4370 2004-02-18 Zack Weinberg <zack@codesourcery.com>
4372 * dwarf2out.c (loclabel_num): Move outside #ifdef
4373 DWARF2_DEBUGGING_INFO and mark with GTY(()).
4374 * config/ia64/ia64.c (struct extern_func_list,extern_func_head):
4376 (ia64_hpux_add_extern_decl): Save the decl, not the name string.
4377 Allocate memory with ggc_alloc. No need to copy anything.
4378 (ia64_hpux_file_end): Update to match.
4380 2004-02-18 Jakub Jelinek <jakub@redhat.com>
4382 * config/i386/i386.c (override_options): Don't imply 3DNow! for -m64
4385 2004-02-18 Ulrich Weigand <uweigand@de.ibm.com>
4387 * config/s390/s390.md ("divmodtidi3"): Use canonical RTL.
4388 ("divmodtisi3"): Likewise.
4389 ("udivmoddi4", "udivmodtidi3"): Likewise.
4390 ("divmodsi4", "divmoddisi3"): Likewise.
4391 ("udivmodsi4", "udivmoddisi3"): Likewise.
4392 ("udivsi3", "umodsi3"): Likewise.
4394 2004-02-18 Ulrich Weigand <uweigand@de.ibm.com>
4396 * config/s390/s390.c (s390_mainpool_start): Delete the main pool
4397 placeholder insn when chunkifying the pool.
4399 2004-02-18 John David Anglin <dave.anglin@nrc-cnrc.gc.ca>
4401 * pa.h (PIC_OFFSET_TABLE_REGNUM): Define to INVALID_REGNUM when not
4402 generating PIC code.
4404 2004-02-18 Kazu Hirata <kazu@cs.umass.edu>
4406 * config/h8300/h8300-protos.h: Add a prototype for
4407 h8300_expand_branch.
4408 * config/h8300/h8300.c (h8300_expand_branch): New.
4409 * config/h8300/h8300.md (ble, bleu, bge, bgeu, blt, bltu, bgt,
4410 bgtu, beq, bne): Call h8300_expand_branch().
4412 2004-02-18 Kazu Hirata <kazu@cs.umass.edu>
4414 * config/h8300/h8300-protos.h: Add prototypes for
4415 h8300_hard_regno_nregs and h8300_hard_regno_mode_ok.
4416 * config/h8300/h8300.c (h8300_hard_regno_nregs): New.
4417 (h8300_hard_regno_mode_ok): Likewise.
4418 * config/h8300/h8300.h (HARD_REGNO_NREGS): Call
4419 h8300_hard_regno_nregs().
4420 (HARD_REGNO_MODE_OK): Call h8300_hard_regno_mode_ok().
4422 2004-02-18 Per Bothner <per@bothner.com>
4424 * cpphash.h (struct cpp_buffer): Restore return_at_eof field. This
4425 partly reverts my 2003-10-01 change, because we're back to logically
4426 including <command line> inside the main line.
4427 * cpplex.c (_cpp_get_fresh_line): Check return_at_eof field.
4428 * cppmacro.c (cpp_scan_nooutput): Set return_at_eof of current buffer.
4429 Fixes PR preprocessor/14103.
4431 * cppfiles.c (_cpp_stack_include): When appropriate decrement
4432 line_table's highest_location, fixing LAST_SOURCE_LINE_LOCATION.
4433 (cpp_push_include): Don't need to increment pfile's line field.
4434 * line-map.h (LAST_SOURCE_LINE_LOCATION): Only decrement by 1.
4436 * c-ppoutput.c (print struct): New first_time field.
4437 (init_pp_output): Set print.first_time.
4438 (pp_file_change): Use print.first_time, rather than MAIN_FILE_P,
4439 which is set also for (say) <command line>. Clear print.first_time.
4441 * cppfiles.c (struct _cpp_file): Comment and type for pch field
4442 does not match the code, so fix both.
4443 (should_stack_file): Inline include_pch_p function.
4444 (include_pch_p): Remove pointless function.
4446 * cpphash.h (struct cpp_buffer): Remove unused search_cached field.
4448 2004-02-18 Kazu Hirata <kazu@cs.umass.edu>
4450 * config/h8300/h8300.md (four define_peephole2's): Use
4451 h8300_regs_ok_for_stm().
4453 2004-02-18 Kazu Hirata <kazu@cs.umass.edu>
4455 * config/h8300/h8300-protos.h: Update the prototype for
4457 * config/h8300/h8300.c (expand_a_rotate): Remove the first
4459 * config/h8300/h8300.md: Update all callers.
4461 2004-02-18 Jan Hubicka <jh@suse.cz>
4463 * simplify-rtx.c (simplify_unary_operation): Deal with logicals on
4465 (simplify_binary_operation): Deal with logicals on floats.
4467 * i386.md (SSE fabs splitters): Emit new patterns.
4468 (SSE cmov splitters): Likewise.
4469 (sse_andv4sf3, sse_nandv4sf3, sse_iorv4sf3, sse_xorv4sf3
4470 (sse_andv2df3, sse_nandv2df3, sse_iorv2df3, sse_xorv2df3): Do not use
4472 (sse_andsf3, sse_nandsf3, sse_xorsf3): Kill.
4473 (sse_anddf3, sse_nanddf3, sse_xordf3): Kill.
4475 2004-02-18 Kazu Hirata <kazu@cs.umass.edu>
4477 * config/h8300/h8300.c (expand_a_rotate): Don't generate insns
4479 (output_a_rotate): Tweak a comment.
4480 * config/h8300/h8300.md (*rotlqi3_1): Change to rotlqi3_1.
4481 (*rotlhi3_1): Change to rotlhi3_1.
4482 (*rotlsi3_1): Change to rotlsi3_1.
4484 2004-02-18 Richard Earnshaw <rearnsha@arm.com>
4487 * arm.c (load_multiple_operation): Don't insist that the source reg
4488 of a post-increment component is the same as the destination.
4489 (store_multiple_operation): Likewise.
4491 2004-02-18 Kazu Hirata <kazu@cs.umass.edu>
4493 * config/h8300/h8300.md: Move movsf patterns into one section
4496 2004-02-18 Kazu Hirata <kazu@cs.umass.edu>
4498 * cfgloop.h, cfgloopanal.c, cpplex.c, except.h, loop-init.c,
4499 loop-unroll.c, scan-decls.c, scan.h, stor-layout.c,
4500 xcoffout.c, xcoffout.h, config/arm/mmintrin.h,
4501 config/mips/linux64.h, config/pa/pa-64.h,
4502 config/rs6000/aix51.h, config/rs6000/aix52.h,
4503 config/rs6000/spe.md, config/sparc/linux.h,
4504 config/sparc/linux64.h: Update copyright.
4506 2004-02-18 Kazu Hirata <kazu@cs.umass.edu>
4508 * config/h8300/h8300.md: Move push patterns into one
4509 section of the file.
4511 2004-02-18 Mark Mitchell <mark@codesourcery.com>
4514 * config/ia64/ia64.c (ia64_struct_value_rtx): Cope with NULL
4517 2004-02-18 Paul Brook <paul@codesourcery.com>
4519 * rtlanal.c (rtx_varies_p): Return 0 for NULL_RTX
4521 2004-02-18 Paul Brook <paul@codesourcery.com>
4524 * dwarf2out.c (loc_descriptor_from_tree): Handle
4525 EXPR_WITH_FILE_LOCATION.
4527 2004-02-18 Jakub Jelinek <jakub@redhat.com>
4529 * config/i386/i386.md (zero_extendqidi2, zero_extendqidi2,
4530 testdi_1_rex64, anddi_2, xordi_1_rex64, xordi_2_rex64): Remove
4531 trailing whitespace from instructions.
4533 2004-02-17 Geoffrey Keating <geoffk@apple.com>
4535 * configure.ac: When generating auto-build.h, pass
4536 --enable-languages to the sub-configure.
4537 Put quotes around ${program_transform_name} when generating
4538 name of as, ld, nm, objdump.
4539 * configure: Regenerate.
4541 2004-02-17 Matt Kraai <kraai@alumni.cmu.edu>
4543 * Makefile.in (s-check, s-config, s-conditions, s-flags)
4544 (s-codes, s-constants, s-emit, s-recog, s-opinit, s-extract)
4545 (s-peep, s-attr, s-attrtab, s-output, s-genrtl, s-modes)
4546 (s-preds, s-iov): Do not depend on move-if-change.
4548 2004-02-17 James E Wilson <wilson@specifixinc.com>
4550 * caller-save.c (insert_restore): Pass mem through copy_rtx.
4551 (insert_save): Likewise.
4553 2004-02-17 Kazu Hirata <kazu@cs.umass.edu>
4555 * config/h8300/h8300.c (h8300_emit_stack_adjustment): Fix a
4558 2004-02-17 Kazu Hirata <kazu@cs.umass.edu>
4560 * config/h8300/h8300.md (*one_complsi2_h8300): Change to
4562 (*one_complsi2_h8300hs): Change to *one_cmplsi2_h8300hs.
4564 2004-02-17 Kazu Hirata <kazu@cs.umass.edu>
4566 * config/h8300/h8300-protos.h: Update the prototype of
4568 * config/h8300/h8300.c (fix_bit_operand): Remove the second
4570 * config/h8300/h8300.md: Update all callers.
4572 2004-02-17 Kazu Hirata <kazu@cs.umass.edu>
4574 * config/h8300/h8300.c (fix_bit_operand): Change the name of
4575 the last argument to "code" from "type".
4577 2004-02-17 Kazu Hirata <kazu@cs.umass.edu>
4579 * config/h8300/h8300.c: Remove an extern declaration of
4580 rtx_equal_function_value_matters.
4582 2004-02-17 Kazu Hirata <kazu@cs.umass.edu>
4584 * config/h8300/h8300.c (fix_bit_operand): Don't generate insns
4586 * config/h8300/h8300.md (*andqi3_1): Change to andqi3_1.
4587 (*iorqi3_1): Change to iorqi3_1.
4588 (*xorqi3_1): Change to xorqi3_1.
4590 2004-02-17 Kazu Hirata <kazu@cs.umass.edu>
4592 * c-common.c, cfghooks.c, rtlanal.c, varasm.c: Fix comment
4595 2004-02-17 Jan Hubicka <jh@suse.cz>
4597 * i386.c (x86_prologue_using_move, x86_epilogue_using_move): Disable for P4.
4599 2004-02-18 Alan Modra <amodra@bigpond.net.au>
4601 PR optimization/14119
4602 * combine.c (try_combine): When attemting to fix unrecognized insns,
4603 don't delete SETs marked with REG_EH_REGION notes.
4605 2004-02-17 Ulrich Weigand <uweigand@de.ibm.com>
4607 * combine.c (simplify_if_then_else): Do not replace
4608 (if_then_else (ne reg 0) (0) (const_int)) by (reg) if the
4611 2004-02017 Steven Bosscher <stevenb@suse.de>
4613 * (c-decl.c, c-semantics.c, calls.c, cgraph.c, cgraphunit.c,
4614 function.c, integrate.c, print-tree.c, toplev.c, tree-optimize.c,
4615 tree.h): Replace DECL_SAVED_INSNS with DECL_STRUCT_FUNCTION.
4616 * ada/utils.c: Likewise.
4617 * cp/decl.c: Likewise.
4618 * f/com.c: Likewise.
4619 * java/class.c: Likewise.
4621 2004-02-17 Kazu Hirata <kazu@cs.umass.edu>
4623 * config/h8300/h8300.md: Fix comment typos.
4625 2004-02-17 Rainer Orth <ro@TechFak.Uni-Bielefeld.DE>
4627 * config/mips/t-iris6gld: Renamed to ...
4628 * config/mips/t-irix-gld: ... this.
4629 * config.gcc (mips-sgi-irix6*): Reflect this
4630 (mips-sgi-irix5*): Use it with GNU ld.
4632 * config/mips/irix6-crti.asm, config/mips/irix6-crtn.asm: Renamed
4634 * config/mips/irix-crti.asm, config/mips/irix-crtn.asm: ... this.
4635 * config/mips/t-irix-gld: Reflect this.
4636 * config/mips/iris6gld.h (STARTFILE_SPEC, ENDFILE_SPEC): Likewise.
4638 * config/mips/iris5gld.h: New file.
4639 * config.gcc (mips-sgi-irix5*): Use it with GNU ld.
4640 Only use collect2 without gas.
4642 * config/mips/iris6.h (IRIX6_STARTFILE_SPEC, IRIX6_ENDFILE_SPEC):
4643 Renamed to IRIX_STARTFILE_SPEC, IRIX_ENDFILE_SPEC.
4644 (STARTFILE_SPEC, ENDFILE_SPEC, SUBTARGET_EXTRA_SPECS): Reflect this.
4645 * config/mips/iris6gld.h (STARTFILE_SPEC, ENDFILE_SPEC): Likewise.
4647 * config/mips/iris6.h (SUBTARGET_EXTRA_SPECS): Moved ...
4648 * config/mips/iris5.h: ... here.
4650 * config/mips/iris5.h (STARTFILE_SPEC, ENDFILE_SPEC): Renamed to
4651 IRIX_STARTFILE_SPEC, IRIX_ENDFILE_SPEC.
4652 (STARTFILE_SPEC, ENDFILE_SPEC): Define.
4654 * config/mips/iris5gas.h (STARTFILE_SPEC, ENDFILE_SPEC): Simplify
4655 using irix_startfile_spec, irix_endfile_spec.
4657 2004-02-16 Gunther Nikl <gni@gecko.de>
4659 * config/m68k/m68k.c: Remove obsolete support for HPUX_ASM.
4661 2004-02-17 Kazu Hirata <kazu@cs.umass.edu>
4663 * config/h8300/h8300.c (h8300_expand_prologue): Don't generate
4666 2004-02-17 Zdenek Dvorak <rakdver@atrey.karlin.mff.cuni.cz>
4668 * cfghooks.c (split_edge): Speed up updating of dominators.
4670 2004-02-17 Mark Mitchell <mark@codesourcery.com>
4673 * c-common.c (flag_abi_version): Remove.
4674 * c-common.h (flag_abi_version): Likewise.
4675 * c-opts.c (c_common_handle_option): Remove OPT_fabi_version case.
4676 * c.opt (fabi-version): Remove.
4677 * calls.c (expand_call): Always pass a function type to
4678 struct_value_rtx. Use convert_memory_address.
4679 * common.opt (fabi-version): Add it.
4680 * flags.h (flag_abi_version): Likewise.
4681 (abi_version_at_least): New macro.
4682 * opts.c (common_handle_option): Add OPT_fabi_version.
4683 * toplev.c (flag_abi_version): Define it.
4684 * config/ia64/ia64.c (ia64_struct_retval_addr_is_first_parm_p):
4686 (ia64_output_mi_thunk): Use it.
4687 (ia64_struct_value_rtx): Likewise.
4689 2004-02-17 Kazu Hirata <kazu@cs.umass.edu>
4691 * config/h8300/h8300.c (h8300_emit_stack_adjustment):
4692 Don't generate insns by hand.
4694 2004-02-17 Andrew Pinski <pinskia@physics.uc.edu>
4697 * doc/invoke.texi (fabi-version): The default is 2 now.
4699 2004-02-17 Zdenek Dvorak <rakdver@atrey.karlin.mff.cuni.cz>
4701 * loop-iv.c: New file.
4702 * Makefile.in (loop-iv.o): New.
4703 * basic_block.h (FOR_BB_INSNS, FOR_BB_INSNS_REVERSE): New macros.
4704 * cfgloop.c (fill_sons_in_loop, get_loop_body_in_dom_order,
4705 num_loop_branches): New functions.
4706 * cfgloop.h (get_loop_body_in_dom_order, num_loop_branches,
4707 iv_analysis_loop_init, iv_get_reaching_def, iv_analyse, get_iv_value,
4708 find_simple_exit, iv_number_of_iterations, iv_analysis_done,
4709 get_simple_loop_desc, free_simple_loop_desc): Declare.
4710 (simple_loop_desc): New inline function.
4711 (struct rtx_iv, struct niter_desc): New.
4712 * cfgloopmanip.c (loopify): Specify semantics more precisely.
4713 * expr.c (force_operand): Handle subregs of expressions created by
4715 * loop-init.c (loop_optimizer_init, loop_optimizer_finalize): Move
4716 parts of the initialization to toplev.c
4717 * loop-unroll.c (loop_exit_at_end_p): New.
4718 (unroll_and_peel_loops): Call iv_analysis_done.
4719 (decide_peel_once_rolling, decide_peel_completely,
4720 decide_unroll_stupid, decide_unroll_constant_iterations,
4721 decide_unroll_runtime_iterations, decide_peel_simple,
4722 peel_loop_simple, unroll_loop_stupid, unroll_loop_constant_iterations,
4723 unroll_loop_runtime_iterations): Use new simple loop analysis.
4724 * loop-unswitch.c (compare_and_jump_seq): New.
4725 (may_unswitch_on_p): Renamed to ...
4726 (may_unswitch_on): Use new iv analysis.
4727 (reversed_condition): Export.
4728 (unswitch_single_loop, unswitch_loop): Use new iv analysis.
4729 * predict.c (estimate_probability): Use new simple loop analysis.
4730 * rtl.h (get_mode_bounds, reversed_condition,compare_and_jump_seq,
4731 canon_condition, simplify_using_condition): Declare.
4732 * stor-layout.c (get_mode_bounds): New.
4733 * toplev.c (rest_of_handle_loop2): Some parts of
4734 initialization/finalization moved here from loop-init.c.
4736 2004-02-17 Kazu Hirata <kazu@cs.umass.edu>
4738 * config/h8300/h8300.h (FIXED_REGISTERS): Add the soft frame
4740 (CALL_USED_REGISTERS): Likewise.
4741 (REG_ALLOC_ORDER): Likewise.
4742 (REG_CLASS) <GENERAL_REGS>: Likewise.
4744 2004-02-16 Geoffrey Keating <geoffk@apple.com>
4746 * doc/md.texi (Insn Canonicalizations): Document left-chaining
4747 in associative operators.
4748 * rtlanal.c (commutative_operand_precedence): Create some new
4749 variables. Prefer a commutative operand on the left, then
4750 binary expressions, then NEG and NOT.
4752 2004-02-16 Matthias Klose <doko@debian.org>
4754 * config/t-slibgcc-elf-ver: Define SHLIB_NAME and SHLIB_SONAME
4755 in terms of SHLIB_SOVERSION.
4756 * config/m68k/t-slibgcc-elf-ver: New file.
4757 * config/pa/t-slibgcc-elf-ver: New file.
4758 * config.gcc (m68k-linux, parisc-linux): Use them when not
4759 sjlj exceptions are not configured.
4761 2004-02-16 Eric Botcazou <ebotcazou@libertysurf.fr>
4763 * config/sparc/sparc.c (get_pc_symbol_name): Mark with GTY(()).
4765 2004-02-16 Zack Weinberg <zack@codesourcery.com>
4767 * sdbout.c (sdb_debug_hooks): Correct the type_decl entry.
4769 2004-02-16 Joseph S. Myers <jsm@polyomino.org.uk>
4771 * doc/sourcebuild.texi: Mention backends.html.
4773 2004-02-16 Kazu Hirata <kazu@cs.umass.edu>
4775 * c-decl.c, c-ppoutput.c, cpphash.h, cpplib.h, dbxout.c,
4776 line-map.c, line-map.h, var-tracking.c: Fix comment
4779 2004-02-16 Richard Henderson <rth@redhat.com>
4781 * cse.c (cse_insn): Don't lose REG_NON_LOCAL_GOTO note.
4783 * fold-const.c (operand_equal_p): Fix VECTOR_CST comparison.
4785 2004-02-15 Kazu Hirata <kazu@cs.umass.edu>
4787 * config/h8300/h8300.md: Remove unnecessary parallels from
4788 all define_insn and define_split patterns.
4790 2004-02-15 Kazu Hirata <kazu@cs.umass.edu>
4792 * config/h8300/h8300.md: Remove explicit (set_attr "cc"
4795 2004-02-15 Bernardo Innocenti <bernie@develer.com>
4797 * config/m68k/m68k.h (PRINT_OPERAND_PUNCT_VALID_P): Restore support for
4800 2004-02-15 Kazu Hirata <kazu@cs.umass.edu>
4802 * config/ia64/ia64.c, config/mips/mips.c,
4803 config/mmix/mmix-modes.def: Fix comment typos.
4805 2004-02-15 Roger Sayle <roger@eyesopen.com>
4807 * c-common.h (GET_DIRECTIVE_LINE): Remove unused macro.
4808 (get_directive_line): Remove unused function prototype.
4810 2004-02-14 Josef Zlomek <zlomekj@suse.cz>
4812 * tree-inline.c (copy_body_r): Do not replace ret_label.
4814 2004-02-14 Jan Hubicka <jh@suse.cz>
4816 * i386.c (x86_four_jump_limit): New variable.
4817 (k8_avoid_jump_misspredicts): Rename to ...
4818 (ix86_avoid_jump_misspredicts): .. this one.
4819 (ix86_pad_returns): Break out from ...
4820 (ix86_reorg): ... this one; do ix86_avoid_jump_misspredicts when asked
4822 * i386.h (TARGET_FOUR_JUMP_LIMIT): New macro.
4824 2004-02-14 Josef Zlomek <zlomekj@suse.cz>
4826 * emit-rtl.c (set_decl_incoming_rtl): Check whether the 0th element of
4829 2004-02-14 Per Bothner <per@bothner.com>
4831 * fix-header.c (line_table): Move local variable in main to global.
4832 * scan.h (line_table): Use it.
4833 * scan-decls.c (scan_decls): Need to call linemap_lookup on token's
4834 line (recently renamed to src_loc) before calling recognized_function.
4836 2004-02-14 Matt Kraai <kraai@alumni.cmu.edu>
4838 * Makefile.in: Fix comment typos.
4840 2004-02-14 Olivier Hainque <hainque@act-europe.fr>
4842 * loop.c (check_dbra_loop): Use gen_int_mode instead of GEN_INT
4843 for start_value when it is directly moved into reg, and factorize
4844 the retrieval of GET_MODE (reg).
4846 2004-02-14 Richard Sandiford <rsandifo@redhat.com>
4848 * config/mips/mips-protos.h (mips_load_got_page): Delete.
4849 (mips_load_got_global): Delete.
4850 (mips_gotoff_page): Declare.
4851 * config/mips/mips.md (UNSPEC_LOAD_GOT): New constant.
4852 (*xgot_lo[sd]i, *got_disp[sd]i, *got_page[sd]i): Build an
4853 UNSPEC_LOAD_GOT pattern rather than a MEM.
4854 (*load_got[sd]i): New patterns.
4855 * config/mips/mips.c (mips_got_alias_set, mips_load_got): Delete.
4856 (mips_load_got_page, mips_load_got_global): Delete.
4857 (mips_gotoff_page): New function.
4858 (override_options): Don't initialize mips_got_alias_set.
4860 2004-02-14 Richard Sandiford <rsandifo@redhat.com>
4862 * config/mips/mips.h (MASK_DEBUG_[ABEFI], TARGET_DEBUG_[ABEFI]_MODE)
4863 (TARGET_MIPS4100, TARGET_MIPS4300, TARGET_MIPS4KC, TARGET_MIPS5KC)
4864 (TARGET_SB1, TUNE_SB1, TUNE_SR71K, BIGGEST_MAX_ARGS_IN_REGISTERS)
4865 (GO_PRINTF, GO_PRINTF2, GO_DEBUG_RTX, DFMODE_NAN, SFMODE_NAN): Delete.
4866 (TARGET_SWITCHES): Remove MASK_DEBUG_[ABEFI].
4867 * config/mips/mips.c: Fix some overly-long lines.
4868 (SINGLE_WORD_MODE_P, PIC_OFFSET_TABLE_MASK): Delete.
4869 (init_cumulative_args): Remove TARGET_DEBUG_E_MODE handling.
4871 2004-02-13 Rainer Orth <ro@TechFak.Uni-Bielefeld.DE>
4873 * configure.ac: Search for as, ld below libexec/gcc.
4874 * configure: Regenerate.
4876 2004-02-14 Ben Elliston <bje@wasabisystems.com>
4878 * config/arm/mmintrin.h (_mm_setwcx): Reverse arguments in call to
4879 __builtin_arm_setwcx ().
4880 * config/arm/arm.c (arm_expand_builtin): Generate operands
4881 correctly and reverse their order in call to gen_iwmmxt_tmcr ().
4883 2004-02-14 Ben Elliston <bje@wasabisystems.com>
4885 * config/arm/arm.c (bdesc_2arg): Correct builtin names "wmulsh"
4886 and "wmuluh" to "wmulsm" and "wmulum", respectively.
4887 * config/arm/arm.h (enum arm_builtins): Rename enumerators to
4888 ARM_BUILTIN_WMULSM and ARM_BUILTIN_WMULUM.
4889 * config/arm/mmintrin.h (_mm_mulhi_pi16): Update intrinsic call.
4890 (_mm_mulhi_pu16): Likewise.
4892 2004-02-13 Zack Weinberg <zack@codesourcery.com>
4894 * xcoffout.c (xcoff_assign_fundamental_type_number): Check
4895 DECL_NAME != 0 before dereferencing.
4897 2004-02-13 Ulrich Weigand <uweigand@de.ibm.com>
4899 * config/s390/s390-protos.h (s390_output_symbolic_const): Remove.
4900 (s390_output_addr_const_extra): Declare.
4901 (s390_output_pool_entry): Remove FILE * argument.
4902 * config/s390/s390.c (s390_output_symbolic_const): Remove.
4903 (s390_output_addr_const_extra): New function.
4904 (print_operand_address): Call output_addr_const instead of
4905 s390_output_symbolic_const.
4906 (print_operand): Likewise.
4907 (s390_output_pool_entry): Use assemble_integer for symbolic constants.
4908 Remove FILE * argument.
4909 * config/s390/s390.h (OUTPUT_ADDR_CONST_EXTRA): Define.
4910 * config/s390/s390.md ("*pool_entry"): Adapt s390_output_pool_entry
4913 2004-02-13 Zdenek Dvorak <rakdver@atrey.karlin.mff.cuni.cz>
4915 * cfgloopanal.c (mark_irreducible_loops): Rewriten.
4916 (struct edge, struct vertex, struct graph): New.
4917 (dump_graph, new_graph, add_edge, dfs, check_irred, for_each_edge,
4918 free_graph): New functions.
4920 2004-02-12 Chris Demetriou <cgd@broadcom.com>
4922 * config/mips/mips.md (casesi_internal, casesi_internal_di):
4923 Use ".set macro" to avoid warnings about multi-instruction
4924 macros, since they're intentional.
4926 2004-02-12 Geoffrey Keating <geoffk@apple.com>
4928 * config/darwin.h: Add include guards. Remove old, now incorrect,
4929 comment about STANDARD_EXEC_PREFIX.
4931 * Makefile.in (install-man): Use $(CPP_INSTALL_NAME) and
4932 $(GCOV_INSTALL_NAME) to install manpages. Remove generic rule
4933 for installing .1 manpages. Add rules for installing cpp
4934 and gcov manpages under their installed names.
4936 2004-02-12 Alexandre Oliva <aoliva@redhat.com>
4938 * configure.ac (gcc_cv_ld): Don't set to LD if target is not
4939 host, but try LD_FOR_TARGET first.
4940 * configure: Rebuilt.
4942 2004-02-12 Zack Weinberg <zack@codesourcery.com>
4944 * dbxout.c: Move declaration of dbxout_type_decl outside
4945 #ifdef DBX_DEBUGGING_INFO.
4946 * c-parse.in: Don't give the asmdef production a type.
4948 2004-02-12 Zack Weinberg <zack@codesourcery.com>
4950 * debug.h (struct gcc_debug_hooks): Add type_decl field.
4951 (debug_nothing_tree_int): Prototype.
4952 (dwarf_debug_hooks): Delete, unused.
4953 * debug.c (do_nothing_debug_hooks): Update.
4954 (debug_nothing_tree_int): New function.
4955 * langhooks.h (struct lang_hooks_for_decls):
4956 Remove builtin_type_decls field.
4957 * langhooks-def.h (LANG_HOOKS_BUILTIN_TYPE_DECLS): Delete.
4958 (LANG_HOOKS_DECLS): Update.
4959 * toplev.c (rest_of_decl_compilation, rest_of_type_compilation):
4960 Use debug_hooks->type_decl.
4961 * dbxout.c (preinit_symbols): New static.
4962 (dbx_debug_hooks, xcoff_debug_hooks): Update.
4963 (dbxout_init): Don't call DBX_OUTPUT_STANDARD_TYPES or
4964 lang_hooks.decls.builtin_type_decls. Do scan preinit_symbols
4965 for symbols to output.
4966 (dbxout_type_decl): New function.
4967 (dbxout_symbol): If called before dbxout_init has run, queue
4968 the symbol for later. Apply DBX_ASSIGN_FUNDAMENTAL_TYPE_NUMBER
4969 to TYPE_DECLs before emitting them.
4970 * xcoffout.c (assign_type_number): Delete.
4971 (xcoff_type_numbers): New static table.
4972 (xcoff_assign_fundamental_type_number): New function.
4973 * xcoffout.h: Define DBX_ASSIGN_FUNDAMENTAL_TYPE_NUMBER, not
4974 DBX_OUTPUT_STANDARD_TYPES. Remove unnecessary #ifdefs.
4975 * sdbout.c: Include varray.h.
4976 (deferred_global_decls): New static.
4977 (sdb_debug_hooks): Update.
4978 (sdbout_global_decl): If we can't emit something right now,
4979 remember it in deferred_global_decls.
4980 (sdbout_finish): Just scan deferred_global_decls; don't call getdecls.
4981 (sdbout_init): Initialize deferred_global_decls.
4982 * Makefile.in: Update dependencies of sdbout.o.
4983 * dwarf2out.c (dwarf2out_type_decl): New function.
4984 (dwarf2_debug_hooks): Update.
4985 * vmsdbgout.c (vmsdbg_debug_hooks): Update.
4986 * c-decl.c (getdecls): Just return 0.
4987 (check_for_loop_decls): Don't use getdecls.
4988 (record_builtin_type): Call debug_hooks->type_decl on the TYPE_DECL.
4989 * c-objc-common.c (c_objc_common_finish_file): Don't use getdecls.
4991 2004-02-12 Ulrich Weigand <uweigand@de.ibm.com>
4993 * config/s390/s390.c (s390_sched_reorder2): Remove.
4994 (TARGET_SCHED_REORDER2): Do not redefine.
4996 2004-02-12 Zack Weinberg <zack@codesourcery.com>
4998 * c-parse.in (maybe_type_qual): Delete.
4999 (maybe_volatile, simple_asm_expr, asmdef, asm_stmt)
5000 (asm_argument): New grammar rules.
5001 (extdef_1): Use asmdef.
5002 (maybeasm): Move down with other asm rules; use simple_asm_expr.
5003 (xexpr): Move up with other expression rules.
5004 (stmt): Use asm_stmt.
5006 * c-typeck.c (build_asm_expr): New function - body mostly
5007 pulled from build_asm_stmt.
5008 (build_asm_stmt): Just handle tacking on the volatile qualifier.
5009 * c-tree.h (build_asm_expr, build_asm_stmt): Update prototypes.
5011 2004-02-12 Richard Sandiford <rsandifo@redhat.com>
5014 * config/mips/mips-protos.h (mips_output_aligned_decl_common): Declare.
5015 (mips_declare_object): Make variadic.
5016 * config/mips/mips.h (ASM_OUTPUT_ALIGNED_DECL_COMMON): Use
5017 mips_output_aligned_decl_common.
5018 * config/mips/mips.c (mips_output_aligned_decl_common): New function.
5019 (mips_declare_object): Make variadic.
5021 2004-02-12 Richard Kenner <kenner@vlsi1.ultra.nyu.edu>
5023 * function.c (update_epilogue_consts): Teach about binary operations.
5025 * emit-rtl.c (set_mem_attributes_minus_bitpos): Don't kill
5026 previous MEM_VOLATILE in REF.
5027 * function.c (fixup_var_refs): Save volatile_ok and set to 1.
5028 * expr.c (emit_block_move_via_movstr): Save and restore volatile_ok.
5030 2004-02-12 Gunther Nikl <gni@gecko.de>
5032 * config.gcc: Restore support for m68k-openbsd.
5034 2004-02-12 Jan Hubicka <jh@suse.cz>
5036 * tree-optimize.c (tree_rest_of_compilation): Do not release
5039 2004-02-11 Matt Kraai <kraai@alumni.cmu.edu>
5041 * doc/install.texi: Fix the spelling of "explicitly".
5043 2004-02-11 Eric Christopher <echristo@redhat.com>
5045 * cppcharset.c (_cpp_interpret_string_notranslate): Rename and
5046 duplicate argument structure of cpp_interpret_string.
5047 * cpphash.h: Move prototype...
5049 * cpplib.c: Fix calls to match new function signature.
5051 2004-02-11 Joseph S. Myers <jsm@polyomino.org.uk>
5054 * cppexp.c (num_binary_op): Don't allow comma operators in #if
5055 constant expressions at all outside C99 mode if pedantic.
5057 2004-02-11 Uros Bizjak <uros@kss-loka.si>
5059 * optabs.h (enum optab_index): Add new OTI_log10 and OTI_log2.
5060 (log10_optab, log2_optab): Define corresponding macros.
5061 * optabs.c (init_optabs): Initialize log10_optab and log2_optab.
5062 * genopinit.c (optabs): Implement log10_optab and log2_optab
5063 using log10?f2 and log2?f2 patterns.
5064 * builtins.c (expand_builtin_mathfn): Handle BUILT_IN_LOG10{,F,L}
5065 using log10_optab, and BUILT_IN_LOG2{,F,L} using log2_optab.
5066 (expand_builtin): Expand BUILT_IN_LOG10{,F,L} and BUILT_IN_LOG2{,F,L}
5067 using expand_builtin_mathfn if flag_unsafe_math_optimizations is set.
5069 * config/i386/i386.md (log10sf2, log10df2, log10xf2, log2sf2,
5070 log2df2, log2xf2): New patterns to implement log10, log10f, log10l,
5071 log2, log2f and log2l built-ins as inline x87 intrinsics.
5073 2004-02-11 Richard Henderson <rth@redhat.com>
5076 * flow.c (insn_dead_p): A clobber of a dead hard register is a
5077 dead insn after reload.
5079 2004-02-11 Ulrich Weigand <uweigand@de.ibm.com>
5081 * tree.h (frame_base_decl): Add GTY marker.
5082 * var-tracking.c (frame_base_decl): Likewise.
5084 2004-02-11 Daniel Berlin <dberlin@dberlin.org>
5086 * dwarf2out.c (output_loc_list): Remove no longer necessary, and now
5088 (add_location_or_const_value_attribute): Use text_section_label,
5089 not TEXT_SECTION_NAME.
5091 2004-02-11 Per Bothner <per@bothner.com>
5093 Represent column numbers using line-map's source_location.
5094 The "next available source_location" is now managed internally by
5095 line-maps.c rather than by clients.
5096 * line-map.h (struct line_map): New field column_bits.
5097 <from_line>: Rename field to start_location.
5098 (struct line_maps): New fields highest_location and max_column_hint.
5099 (linemap_check_files_exited): New declaration.
5100 (linemap_line_start): New declaration.
5101 (linemap_add): Remove from_line parameter; use highest_location field.
5102 (SOURCE_LINE, LAST_SOURCE_LINE): Modify to use column_bits.
5103 (SOURCE_COLUMN, LAST_SOURCE_LINE_LOCATION): New macros.
5104 (CURRENT_LINE_MAP): Remove macro.
5105 (linemap_position_for_column): New inline function.
5106 * line-map.c (linemap_init): Clear new fields.
5107 (linemap_check_files_exited): New function, extracted from ...
5108 (linemap_free): Use linemap_check_files_exited.
5109 (linemap_add): Remove from_line parameter. Various updates.
5110 (linemap_line_start): New function.
5111 (linemap_lookeup): Update for new field names.
5112 * cpphash.h (struct cpp_reader) <map>: Field removed. Because
5113 linemap_position_for_column may unpredictably change the current map,
5114 it is cleaner and simpler for us to not cache it in cpp_reader.
5115 (struct cpp_buffer): New sysp field.
5116 Changed warned_cplusplus_comments and from_stage3 to bitfields.
5117 * cppinit.c (cpp_read_min_file): pfile->map no longer exists.
5118 * cpplib.c (do_line, do_linemarker, _cpp_do_file_change): Get
5119 current map using linemap_lookup.
5120 (do_linemarker): Also set buffer's sysp field.
5121 (destringize_and_run): No longer need to decrement current line.
5122 * cppfiles.c (_cpp_stack_file): Set sysp from and in buffer.
5123 (search_path_head, open_file_failed): Use buffer's sysp.
5124 (cpp_make_system_header): Get current map using linemap_lookup.
5125 Also set buffer's sysp flag.
5126 * cppmacro.c (_cpp_builtin_macro_text): Likewise use linemap_lookup.
5127 * cpphash.h (CPP_INCREMENT_LINE): New macro.
5128 (struct cpp_buffer): Moved fields saved_cur, saved_rlimit to ...
5129 (struct cpp_reader): ... and adding saved_line_base field.
5130 * cpptrad.c (_cpp_overlay_buffer, _cpp_remove_overlay):
5131 Update accordingly. Don't adjust line.
5132 (_cpp_scan_out_logical_line): Use CPP_INCREMENT_LINE.
5133 * cpphash.c (CPP_IN_SYSTEM_HEADER): Replaced macro by ...
5134 (cpp_in_system_header): ... new inline function, using buffer's sysp.
5135 * cpperror.c (_cpp_begin_message): Update to use cpp_in_system_header.
5136 * cpplex.c (_cpp_lex_direct): Likewise.
5137 * cppmacro.c (_cpp_builtin_macro_text): Likewise.
5138 * cppmacro.c (_cpp_create_definition): Use buffer's sysp field.
5139 * cpplib.h (struct cpp_token): Rename line field to src_loc.
5140 Remove col field as it is now subsumed by src_loc.
5141 * cpperror.c: Update various field, parameter, and macro names.
5142 (print_location): If col==0, try SOURCE_COLUMN of line.
5143 (cpp_error): Use cur_token's src_loc field, rather than line+col.
5144 * cpplib.c (do_diagnostic): Token's src_loc fields replaces line+col.
5145 * cpplex.c (_cpp_process_line_notes, _cpp_lex_direct,
5146 _cpp_skip_block_comment): Use CPP_INCREMENT_LINE.
5147 (_cpp_temp_token): Replace cpp_token's line+col fields by src_loc.
5148 (_cpp_get_fresh_line): Don't need to adjust line for missing newline.
5149 (_cpp_lex_direct): Use linemap_position_for_column.
5150 * c-ppoutput.c (maybe_print_line, print_line): Don't take map
5151 parameter. Instead get it from the line_table global. Adjust callers.
5152 (print): Remove map field. Replace line field to src_line.
5153 (init_pp_output, account_for_newlines, maybe_print_line): Adjust.
5154 (cb_line_change): Use SOURCE_COLUMN. Minor optimizations.
5155 (pp_file_change): Use MAIN_FILE_P since we cannot checked print.map.
5156 Use LAST_SOURCE_LINE_LOCATION to "catch up" after #include.
5157 * cpptrad.c (copy_comment): Rename variable.
5158 * c-lex.c (map): Remove static variable, for same reason we removed
5159 cpp_reader's map field.
5160 (cb_line_change, cb_def_pragma, cb_define, cb_undef): Hence we need
5161 to call linemap_lookup.
5162 (cb_line_change): Token's line field replaced by src_loc.
5163 (fe_file_change): Use MAINFILE_P and LAST_SOURCE_LINE macros.
5166 * cpphash.h, cpperror.c, cpplib.h: Some renames of fileline to
5169 2004-02-11 Hartmut Penner <hpenner@de.ibm.com>
5171 * config/rs6000/altivec.md (*movv4si_internal): At least one
5172 operand must be register_operand.
5173 (*movv8hi_internal1): Likewise.
5174 (*movv16qi_internal1): Likewise.
5175 (*movv4sf_internal1): Likewise.
5177 2004-02-10 Aldy Hernandez <aldyh@redhat.com>
5179 * config/rs6000/spe.md ("*movv2si_internal"): Check for register
5181 (movv4hi_internal): Same.
5182 (movv2sf_internal): Same.
5183 (movv1di_internal): Same.
5185 2004-02-11 Thiemo Seufer <seufer@csv.ica.uni-stuttgart.de>
5187 * config/mips/mips.h (TARGET_OLDABI): Define. Use TARGET_NEWABI and
5188 TARGET_OLDABI consistently.
5189 * config/mips/mips.c (function_arg,mips_setup_incoming_varargs,
5190 mips_va_arg,override_options,compute_frame_size,
5191 mips_initial_elimination_offset,mips16_fp_args,build_mips16_call_stub
5192 ,mips_return_in_memory,mips_strict_argument_naming): Use TARGET_NEWABI
5193 and TARGET_OLDABI consistently.
5194 * config/mips/mips.md (exception_receiver): Likewise.
5195 * config/mips/linux64.h: Likewise.
5197 2004-02-11 Hartmut Penner <hpenner@de.ibm.com>
5199 * gcc/config/rs6000/rs6000.c (rs6000_override_options)
5200 Set AltiVec ABI and vrsave as default for ppc64 linux.
5201 (init_cumulative_args): Post error, if try to return
5202 value in AltiVec register without enable AltiVec.
5203 (function_arg_advance): Ditto for passing arguments.
5205 2004-02-11 Richard Sandiford <rsandifo@redhat.com>
5207 * emit-rtl.c (mark_label_nuses): Check that a LABEL_REF refers to
5208 a label before updating its usage count.
5210 2004-02-10 Matt Kraai <kraai@alumni.cmu.edu>
5212 * doc/install.texi: Remove extra cd.
5214 2004-02-10 Ziemowit Laski <zlaski@apple.com>
5216 * c-common.c (vector_size_helper): Remove; call
5217 reconstruct_complex_type() instead.
5218 * tree.c (reconstruct_complex_type): New function
5219 (formerly vector_size_helper() in c-common.c).
5220 (make_vector): Make externally visible.
5221 * tree.h (reconstruct_complex_type, make_vector): Add prototypes.
5223 2004-02-10 Kazu Hirata <kazu@cs.umass.edu>
5225 * config/h8300/h8300-protos.h: Add a prototype for
5226 h8300_regs_ok_for_stm.
5227 * config/h8300/h8300.c (h8300_regs_ok_for_stm): New.
5228 * config/h8300/h8300.md (stm_h8300s_2_advanced,
5229 stm_h8300s_2_normal, stm_h8300s_2, stm_h8300s_3_advanced,
5230 stm_h8300s_3_normal, stm_h8300s_3, stm_h8300s_4_advanced,
5231 stm_h8300s_4_normal, stm_h8300s_4, ldm_h8300s_2_advanced,
5232 ldm_h8300s_2_normal, ldm_h8300s_2, ldm_h8300s_3_advanced,
5233 ldm_h8300s_3_normal, ldm_h8300s_3, ldm_h8300s_4_advanced,
5234 ldm_h8300s_4_normal, ldm_h8300s_4): Use
5235 h8300_regs_ok_for_stm().
5237 2004-02-10 Danny Smith <dannysmith@users.sourceforge.net>
5240 * real.c (real_from_string): Look for 'X' as well as 'x' in
5243 2004-02-10 Kazu Hirata <kazu@cs.umass.edu>
5245 * config/h8300/h8300.md: Remove an incorrect comment about
5246 peephole2. Add comments.
5248 2004-02-10 Josef Zlomek <zlomekj@suse.cz>
5251 * emit-rtl.c (set_decl_incoming_rtl): New.
5252 * tree.h (set_decl_incoming_rtl): New.
5253 * function.c (assign_parms): Use set_decl_incoming_rtl for setting
5255 * ada/misc.c (adjust_decl_rtl): Likewise.
5257 2004-02-10 Per Bothner <per@bothner.com>
5259 * c-opts.c (c_common_post_options): Don't emit working directory
5260 in cpp output if -P was specified.
5262 2004-02-10 Paolo Bonzini <bonzini@gnu.org>
5265 * fold-const.c (fold) <NEGATE_EXPR>: Convert result of
5266 negate_expr back to the original type.
5268 2004-02-10 Alan Modra <amodra@bigpond.net.au>
5270 * config/rs6000/linux64.h (MD_FALLBACK_FRAME_STATE_FOR): Don't
5273 2004-02-10 Paolo Bonzini <bonzini@gnu.org>
5275 * rtl.h (schedule_insns, schedule_ebbs, fix_sched_param,
5276 gen_lowpart_SUBREG): Move under the file in which they
5277 are actually declared.
5279 2004-02-10 Arnaud Charlet <charlet@act-europe.fr>
5281 * doc/sourcebuild.texi: Add libada documentation.
5283 * doc/install.texi: Update documentation on Ada build, now
5284 that the GNAT lib and tools are built automatically.
5286 2004-02-10 Richard Sandiford <rsandifo@redhat.com>
5288 * config/mips/mips.h (TARGET_GPWORD): Return false for TARGET_NEWABI
5291 2004-02-09 Ziemowit Laski <zlaski@apple.com>
5293 * objc/objc-act.c (get_super_receiver): Move '#ifdef OBJCPLUS'
5294 boundaries outside build_component_ref() call (a macro in ObjC++).
5296 2004-02-09 Bob Wilson <bob.wilson@acm.org>
5298 * config/xtensa/xtensa-protos.h (xtensa_copy_incoming_a7): Update.
5299 (init_cumulative_args): Likewise.
5300 (a7_overlap_mentioned_p): Delete prototype.
5301 * config/xtensa/xtensa.c (struct machine_function): Replace
5302 incoming_a7_copied field with need_a7_copy and vararg_a7 flags.
5303 Add set_frame_ptr_insn field.
5304 (xtensa_emit_move_sequence): Update call to xtensa_copy_incoming_a7.
5305 (xtensa_copy_incoming_a7): Rewrite to check need_a7_copy flag and check
5306 if the operand is an argument in a7. If so, copy a7 to a new pseudo
5307 at the function entry and replace the operand with the pseudo.
5308 (init_cumulative_args): Remove unused arguments. Add new "incoming"
5309 argument and record this flag in CUMULATIVE_ARGS.
5310 (function_arg): Remove result_mode and special-case code to handle
5311 arguments in a7. Instead, set need_a7_copy flag when there is an
5312 incoming argument in a7.
5313 (xtensa_expand_prologue): Remove code to search for set_frame_ptr insn
5314 and use the value recorded in cfun->machine->set_frame_ptr_insn.
5315 (xtensa_builtin_saveregs): Check for negative gp_left value. Set
5316 need_a7_copy and vararg_a7 flags. Use move_block_from_reg instead of
5318 (a7_overlap_mentioned_p): Delete.
5319 * config/xtensa/xtensa.h (CUMULATIVE_ARGS): Add "incoming" flag.
5320 (INIT_CUMULATIVE_ARGS, INIT_CUMULATIVE_INCOMING_ARGS): Remove useless
5321 arguments to init_cumulative_args and pass "incoming" flag instead.
5322 (BLOCK_REG_PADDING): Delete.
5323 * config/xtensa/xtensa.md (movdi, movsf, movdf): Remove unnecessary
5324 checks for reload_in_progress and reload_completed. Update calls to
5325 xtensa_copy_incoming_a7.
5326 (ashlsi3): Rename existing insn to ashlsi3_internal. Add expander
5327 to call xtensa_copy_incoming_a7.
5329 2004-02-09 DJ Delorie <dj@redhat.com>
5331 * config/i386/xm-djgpp.h (GCC_DRIVER_HOST_INITIALIZATION): No
5332 longer modify standard_exec_prefix, standard_bindir_prefix, or
5333 standard_startfile_prefix.
5335 2004-02-09 James E Wilson <wilson@specifixinc.com>
5338 * c-common.c (c_expand_expr, case STMT_EXPR): Change expand_expr call
5339 to expand_expr_real call, and pass in alt_rtl as last argument.
5342 * builtin-types.def (BT_WORD, BT_FN_WORD_PTR): New.
5343 * builtins.c (expand_builtin): Handle BUILT_IN_EXTEND_POINTER.
5344 * builtins.def (BUILT_IN_EXTEND_POINTER): New.
5345 * except.c (expand_builtin_extend_pointer): New.
5346 * except.h (expand_builtin_extend_pointer): Declare.
5348 2004-02-09 David Edelsohn <edelsohn@gnu.org>
5350 * config/rs6000/rs6000.c (rs6000_emit_move): Remove splitting slow
5351 unaligned loads and stores.
5353 2004-02-09 Rainer Orth <ro@TechFak.Uni-Bielefeld.DE>
5355 * config/mips/iris5.h (BSS_SECTION_ASM_OP): Define.
5356 * config/mips/iris6.h (BSS_SECTION_ASM_OP): Undef.
5358 * config/mips/iris6.h (TARGET_ASM_NAMED_SECTION): Moved ...
5359 * config/mips/iris5.h: ... here.
5360 * config/mips/iris5gas.h (TARGET_ASM_NAMED_SECTION): Remove.
5362 * config/mips/iris6.h (EXTRA_SECTION_FUNCTIONS): Move ...
5363 * config/mips/iris5.h: ... here.
5365 2004-02-09 Rainer Orth <ro@TechFak.Uni-Bielefeld.DE>
5367 * configure.ac: Remove default executable files before AC_PROG_CC.
5368 * configure: Regenerate.
5370 2004-02-09 Kazu Hirata <kazu@cs.umass.edu>
5373 * config/h8300/h8300.c (byte_reg): Call abort() if asked to
5374 print a operand other than a register.
5376 2004-02-09 Roger Sayle <roger@eyesopen.com>
5378 * fold-const.c (fold) <NOP_EXPR>: Use the original type conversion
5379 tree code rather than call fold_convert, which doesn't specify a
5380 default floating point to integer conversion.
5382 2004-02-08 Bernardo Innocenti <bernie@develer.com>
5384 * config/m68k/m68k.c, config/m68k/m68k.md (SGS, SGS_CMP_ORDER): Remove
5385 code to support SGS assembler. Reformat adjacent code where possible.
5386 * config/m68k/m68k.c (switch_table_difference_label_flag): Remove
5388 * config/m68k/m68k.h (PRINT_OPERAND_PUNCT_VALID_P): Remove support
5390 * config/m68k/linux.h, config/m68k/m68k.c,
5391 * config/m68k/math-68881.h: Replace `%#' with `#' in inline asm
5392 macros and asm_printf() format strings.
5393 * config/m68k/m68kelf.h (ASM_OUTPUT_CASE_END): Remove macro definition.
5394 * config/m68k/linux.h: Update copyright.
5395 * config/m68k/linux.h, config/m68k/m68k.c: Remove traling whitespace.
5397 2004-02-08 Andreas Schwab <schwab@suse.de>
5398 Bernardo Innocenti <bernie@develer.com>
5400 * config/m68k/m68k.h (REGISTER_NAMES): Prefix each name with
5402 * (M68K_FP_REG_NAME): New macro to specify an alternate name for the
5403 frame pointer register, overridable by OS targets.
5404 * (M68K_REGNAME): Macro to obtain register name for asm output,
5405 eventually replacing %a6 with M68K_FP_REG_NAME.
5406 * config/m68k/coff.h (REGISTER_NAMES): Don't redefine.
5407 * config/m68k/linux.h (REGISTER_NAMES): Likewise.
5408 * config/m68k/m68kelf.h (REGISTER_NAMES): Likewise.
5409 * config/m68k/netbsd-elf.h (REGISTER_NAMES): Likewise.
5410 * config/m68k/m68k.c: Use M68K_REGNAME(x) in place of reg_names[x].
5412 2004-02-08 Kazu Hirata <kazu@cs.umass.edu>
5414 * target-def.h (TARGET_STRUCT_VALUE_RTX): Define as
5415 hook_rtx_tree_int_null.
5416 * targhooks.c (default_struct_value_rtx): Remove.
5417 * targhooks.h: Remove the prototype for
5418 default_struct_value_rtx.
5419 * config/alpha/alpha.c, config/arc/arc.c, config/avr/avr.c,
5420 config/fr30/fr30.c, config/h8300/h8300.c, config/i386/i386.c,
5421 config/ip2k/ip2k.c, config/iq2000/iq2000.c,
5422 config/m32r/m32r.c, config/mcore/mcore.c, config/mips/mips.c,
5423 config/mn10300/mn10300.c, config/pdp11/pdp11.c,
5424 config/rs6000/rs6000.c, config/s390/s390.c,
5425 config/stormy16/stormy16.c, config/v850/v850.c,
5426 config/xtensa/xtensa.c (TARGET_STRUCT_VALUE_RTX): Remove.
5427 * doc/tm.texi (TARGET_STRUCT_VALUE_RTX): Document the default.
5429 2004-02-08 Joseph S. Myers <jsm@polyomino.org.uk>
5431 * README.Portability: Change "ISO C89" to "ISO C90".
5432 * c-parse.in (primary, initelt): Likewise.
5434 2004-02-08 Richard Sandiford <rsandifo@redhat.com>
5436 * real.c (encode_ibm_extended): Normalize the input value before
5437 converting it to a double. Handle the case where a normal value
5440 2004-02-08 Kazu Hirata <kazu@cs.umass.edu>
5442 * c-objc-common.c (c_cannot_inline_tree_fn): Fix a typo in a
5444 * cse.c (preferrable): Change to preferable. Update all of its
5446 * genautomata.c (ainsn): Change
5447 first_ainsn_with_given_equialence_num to
5448 first_ainsn_with_given_equivalence_num. Update all of its
5451 2004-02-08 Jan Hubicka <jh@suse.cz>
5453 * schedule-ebb.c (schedule_ebbs): Do not allocate reg life data.
5455 2004-02-07 David Edelsohn <edelsohn@gnu.org>
5457 * function.c (assign_parms): Fix formatting.
5459 2004-02-07 Kazu Hirata <kazu@cs.umass.edu>
5461 * default.h (PROMOTE_PROTOTYPES): Remove.
5462 * system.h (PROMOTE_FUNCTION_RETURN, PROMOTE_PROTOTYPES,
5463 STRUCT_VALUE_REGNUM, SETUP_INCOMING_VARARGS,
5464 EXPAND_BUILTIN_SAVEREGS): Poison.
5465 * target-def.h (TARGET_PROMOTE_FUNCTION_RETURN): Define as
5466 hook_bool_tree_false.
5467 (TARGET_PROMOTE_PROTOTYPES): Likewise.
5468 * target.h: Replace SETUP_INCOMING_VARARGS with
5469 targetm.calls.setup_incoming_varargs().
5470 * targhooks.c (default_promote_function_return): Remove.
5471 (default_promote_prototypes): Likewise.
5472 (default_struct_value_rtx): Always abort().
5473 (default_expand_builtin_saveregs): Always print an error
5475 (default_setup_incoming_varargs): Do nothing.
5476 (default_pretend_outgoing_varargs_named): Don't depend on
5477 SETUP_INCOMING_VARARGS.
5478 * targhooks.h: Remove the prototype for
5479 default_promote_function_return and
5480 default_promote_prototypes.
5482 2004-02-07 Kazu Hirata <kazu@cs.umass.edu>
5484 * system.h (SHARED_SECTION_ASM_OP): Poison.
5485 * varasm.c (data_section): Don't use SHARED_SECTION_ASM_OP.
5486 * doc/tm.texi (SHARED_SECTION_ASM_OP): Remove.
5488 2004-02-07 Zack Weinberg <zack@codesourcery.com>
5491 * c-decl.c (diagnose_mismatched_decls): Only give special
5492 treatment when olddecl is DECL_BUILT_IN, if C_DECL_INVISIBLE
5494 (merge_decls): Don't clear DECL_BUILT_IN_CLASS and
5495 DECL_FUNCTION_CODE when defining a built-in function.
5496 Don't update DECL_ESTIMATED_INSNS.
5497 * dwarf2out.c (dwarf2out_decl): Don't ignore built-in
5499 * tree.h: Delete DECL_ESTIMATED_INSNS.
5500 * tree-inline.c (struct inline_data): Delete inlined_insns field.
5501 (expand_call_inline, optimize_inline_calls): Don't update
5502 DECL_ESTIMATED_INSNS nor inlined_insns.
5503 * cgraphunit.c (cgraph_analyze_function): Don't update
5504 DECL_ESTIMATED_INSNS.
5506 2004-02-07 Zack Weinberg <zack@codesourcery.com>
5508 * c-common.c (shadow_warning): Delete.
5509 * c-common.h (free_parser_stacks, shadow_warning, sw_kind): Delete.
5510 * c-decl.c (warn_if_shadowing): Issue shadow warnings directly.
5511 * c-opts.c (c_common_parse_file): Don't call free_parser_stacks.
5512 * c-parse.in (free_parser_stacks): Delete.
5514 2004-02-07 Nathanael Nerode <neroden@gcc.gnu.org>
5516 * Makefile.in, config/t-slibgcc-darwin, config/t-slibgcc-elf-ver,
5517 config/t-slibgcc-sld, config/mips/t-iris5-6, config/sh/t-linux:
5518 Use the top level mkinstalldirs, not the one in the gcc subdir.
5519 * mkinstalldirs: Remove (from the gcc subdir).
5521 2004-02-07 Roger Sayle <roger@eyesopen.com>
5524 * fold-const.c (fold_convert): New function to provide type
5525 conversion to the middle-end without using convert.
5526 (negate_expr, associate_trees, size_diffop, omit_one_operand,
5527 operand_equal_for_comparison_p, pedantic_omit_one_operand,
5528 invert_truthvalue, optimize_bit_field_compare, range_binop,
5529 decode_field_reference, make_range, build_range_check, unextend,
5530 fold_truthop, extract_muldiv_1, fold_mathfn_compare,
5531 fold_binary_op_with_conditional_arg, fold_inf_compare,
5532 fold_single_bit_test, fold, multiple_of_p): Replace all calls to
5533 convert with calls to fold_convert.
5535 2004-02-07 Jan Hubicka <jh@suse.cz>
5537 * genrecog.c (find_operand): add extra argument stop.
5538 (validate_pattern): Verify that mach_dup is duplicating operand
5539 defined lexically earlier.
5541 2004-02-07 Kazu Hirata <kazu@cs.umass.edu>
5543 * config.gcc: Don't mention MAX_LONG_TYPE_SIZE.
5544 * system.h (MAX_LONG_TYPE_SIZE, MAX_LONG_DOUBLE_TYPE_SIZE,
5545 MAX_WCHAR_TYPE_SIZE, GCOV_TYPE_SIZE): Poison.
5546 * config/avr/avr.h, config/h8300/h8300.h, config/i386/i386.h,
5547 config/ia64/ia64.h, config/ip2k/ip2k.h,
5548 config/iq2000/iq2000.h, config/mips/iris5.h,
5549 config/mips/mips.h, config/pa/pa-64.h, config/pa/pa.h,
5550 config/rs6000/aix51.h, config/rs6000/aix52.h,
5551 config/rs6000/darwin.h, config/rs6000/rs6000.h,
5552 config/s390/s390.h, config/sh/sh.h, config/sparc/freebsd.h,
5553 config/sparc/linux.h, config/sparc/linux64.h,
5554 config/sparc/netbsd-elf.h, config/sparc/sparc.h,
5555 config/xtensa/xtensa.h: Remove the definitions of
5556 MAX_LONG_TYPE_SIZE, MAX_LONG_DOUBLE_TYPE_SIZE, and/or
5557 MAX_WCHAR_TYPE_SIZE.
5558 * doc/tm.texi (MAX_LONG_TYPE_SIZE, MAX_LONG_DOUBLE_TYPE_SIZE,
5559 MAX_WCHAR_TYPE_SIZE, GCOV_TYPE_SIZE): Remove.
5561 2004-02-07 Stephane Carrez <stcarrez@nerim.fr>
5564 * config/m68hc11/m68hc11.md ("doloop_end"): Pass dummy arguments to
5567 2004-02-07 Josef Zlomek <zlomekj@suse.cz>
5569 * var-tracking.c (vt_add_function_parameters): Surround checkings by
5570 #ifdef ENABLE_CHECKING and #endif.
5572 2004-02-07 Roger Sayle <roger@eyesopen.com>
5574 * fold-const.c (negate_expr_p, negate_expr): Optimize -(A+B) into
5575 either (-A)-B or (-B)-A, if A or B is easily negated respectively.
5576 (fold) <MINUS_EXPR>: Optimize (A*C) - (B*C) -> (A-B)*C for both
5577 integer types and floating point with unsafe_math_optimizations.
5578 Add similar optimization for (A*C1) - (A*C2) -> A*(C1-C2).
5579 Optimize A - B as A + (-B), if B is easily negated.
5581 2004-02-07 Kazu Hirata <kazu@cs.umass.edu>
5583 * c-ppoutput.c, cfganal.c, diagnostic.h, print-rtl.c,
5584 config/darwin.c, config/darwin.h, config/ia64/ia64-c.c,
5585 config/m32r/linux.h, config/rs6000/ppc64-fp.c,
5586 config/sparc/openbsd.h, doc/makefile.texi, doc/passes.texi:
5589 2004-02-07 Kazu Hirata <kazu@cs.umass.edu>
5591 * c-ppoutput.c, var-tracking.c: Fix comment typos.
5593 2004-02-06 James E Wilson <wilson@specifixinc.com>
5595 * config/ia64/linux.h (MD_FALLBACK_FRAME_STATE_FOR): Only define for
5596 glibc 2.3 or better.
5598 2004-02-06 Kazu Hirata <kazu@cs.umass.edu>
5600 * doc/tm.texi (TARGET_FLOAT_LIB_COMPARE_RETURNS_BOOL): Change
5601 to FLOAT_LIB_COMPARE_RETURNS_BOOL.
5603 2004-02-07 Alan Modra <amodra@bigpond.net.au>
5605 * config/rs6000/t-linux64 (LIB2FUNCS_EXTRA): Add darwin-ldouble.c.
5606 (SHLIB_MAPFILES): Add libgcc-ppc64.ver.
5607 (SHLIB_MKMAP_OPTS): Delete.
5608 (TARGET_LIBGCC2_CFLAGS): Add -specs.
5609 (bispecs): Add rule.
5610 * config/rs6000/libgcc-ppc64.ver: New file.
5611 * config/rs6000/ppc64-fp.c (__fixtfdi, __floatditf): New functions.
5612 (__floatdidf, __floatdisf): Optimize multiply.
5613 (__fixunstfdi): New function.
5614 * config/rs6000/rs6000.c (rs6000_complex_function_value): Allow for
5615 real and imag parts larger than one register.
5616 (function_arg): Correct type of reg used when fp arg split partially
5618 * config/rs6000/darwin-ldouble.c: Protect with #if !_SOFT_FLOAT
5619 and __MACH__ or __powerpc64__.
5621 2004-02-06 Roger Sayle <roger@eyesopen.com>
5622 Ulrich Weigand <uweigand@de.ibm.com>
5624 * builtins.c (expand_builtin_signbit): Use extract_bit_field instead
5625 of gen_highpart or gen_lowpart when the floating point format is
5626 wider than the result mode.
5628 2004-02-06 Andrew Pinski <pinskia@physics.uc.edu>
5630 * dwarf2out.c (loclabel_num): Move into #ifdef
5631 DWARF2_DEBUGGING_INFO.
5633 2004-02-06 Ziemowit Laski <zlaski@apple.com>
5635 * objc/objc-act.c (build_super_template) the 'class' field of
5636 'struct _objc_super' shall be named 'super_class' #ifdef OBJCPLUS.
5637 (get_super_receiver): Likewise.
5639 2004-02-06 Kazu Hirata <kazu@cs.umass.edu>
5641 * reload1.c (check_eliminable_occurrences): Optimize the reset
5643 (eliminate_regs_in_insn): Likewise.
5645 2004-02-06 Daniel Berlin <dberlin@dberlin.org>
5646 Josef Zlomek <zlomekj@suse.cz>
5648 * dwarf2out.c (struct gcc_debug_hooks): Call dwarf2out_begin_function
5649 at the beginning of function, call dwarf2out_var_location for
5650 NOTE_INSN_VAR_LOCATION note.
5651 (struct var_loc_node, struct var_loc_list_def, loclabel_num,
5652 decl_loc_table): New.
5653 (lookup_decl_loc): New function.
5654 (add_var_loc_to_decl): New function.
5655 (based_loc_descr): Added parameter can_use_fbreg, DW_OP_fbreg is used
5656 only if can_use_fbreg.
5657 (mem_loc_descriptor): Added parameter can_use_fbreg, pass it to other
5659 (loc_descriptor): Likewise. Process VAR_LOCATION.
5660 (concat_loc_descriptor): Call loc_descriptor with can_use_fbreg == true.
5661 (loc_descriptor_from_tree): Call mem_loc_descriptor with
5662 can_use_fbreg == true.
5663 (add_location_or_const_value_attribute): Added parameter enum
5664 dwarf_attribute attr, generate attribute ATTR. Create the location list.
5665 (add_bound_info): Call loc_descriptor with can_use_fbreg == true.
5666 (gen_formal_parameter_die): Call add_location_or_const_value_attribute
5667 with attr == DW_AT_location.
5668 (gen_subprogram_die): Generate the location list for DW_AT_frame_base
5669 if frame_base_decl is defined and has a location list.
5670 (gen_variable_die): Call add_location_or_const_value_attribute with
5671 attr == DW_AT_location.
5672 (dwarf2out_var_location): New function.
5673 (dwarf2out_begin_function): New function.
5674 (dwarf2out_init): Create decl_loc_table.
5676 2004-02-06 Ulrich Weigand <uweigand@de.ibm.com>
5678 * loop.c (force_movables): Transitively increase the priorities of
5679 all insns forces by an insn, not just the first one.
5681 2004-02-06 Josef Zlomek <zlomekj@suse.cz>
5682 Daniel Berlin <dberlin@dberlin.org>
5684 Josef Zlomek <zlomekj@suse.cz>
5685 * Makefile.in (var-tracking.o): New.
5686 * common.opt (fvar-tracking): New.
5687 * flags.h (flag_var_tracking): New.
5688 * gengtype.c (adjust_field_rtx_def): NOTE_INSN_VAR_LOCATION was added.
5689 * opts.c (common_handle_option): Add OPT_fvar_tracking.
5690 * print-rtl.c (print_rtx): NOTE_INSN_VAR_LOCATION was added.
5691 * rtl.c (note_insn_name): Likewise.
5692 * rtl.def (VAR_LOCATION): New.
5693 * rtl.h (NOTE_VAR_LOCATION): New.
5694 (NOTE_VAR_LOCATION_DECL): New.
5695 (NOTE_VAR_LOCATION_LOC): New.
5696 (enum insn_note): NOTE_INSN_VAR_LOCATION was added.
5697 (variable_tracking_main): New exported function.
5698 * timevar.def (TV_VAR_TRACKING): New.
5699 * toplev.c (enum dump_file_index): Added DFI_vartrack.
5700 (dump_file): "vartrack" was added (-dV).
5701 (flag_var_tracking): New.
5702 (f_options): "var-tracking" was added.
5703 (rest_of_handle_variable_tracking): New function.
5704 (rest_of_compilation): Run variable tracking.
5705 (process_options): If user has not specified flag_var_tracking set it
5706 according to optimize, debug_info_level and debug_hooks.
5707 * tree.h (frame_base_decl): New.
5708 * var-tracking.c: New file.
5709 * config/ia64/ia64.c (ia64_flag_var_tracking): New variable.
5710 (ia64_override_options): Set flags to run variable tracking in machine
5711 dependent reorg instead of toplev.c.
5712 (ia64_reorg): Run variable tracking if wanted.
5713 * doc/invoke.texi: Mention variable tracking in -dV,
5714 add and -fvar-tracking.
5715 * doc/passes.texi: Added variable tracking pass.
5717 Daniel Berlin <dberlin@dberlin.org>
5718 * debug.h (struct gcc_debug_hooks): Added var_location debug hook.
5719 * dbxout.c (dbx_debug_hooks): Likewise.
5720 (xcoff_debug): Likewise.
5721 * debug.c (do_nothing_debug_hooks): Likewise.
5722 * dwarf2out.c (dwarf2_debug_hooks): Likewise.
5723 * dwarfout.c (dwarf_debug_hooks): Likewise.
5724 * sdbout.c (sdb_debug_hooks): Likewise.
5725 * vmsdbgout.c (vmsdbg_debug_hooks): Likewise.
5726 * final.c (final_scan_insn): Call var_location debug hook for each
5727 NOTE_INSN_VAR_LOCATION.
5729 2004-02-06 Jan Hubicka <jh@suse.cz>
5731 * flow.c (update_life_info): Allocate reg_deaths when called from
5733 (attempt_auto_inc): Update life ranges accordingly.
5735 2004-02-06 Ulrich Weigand <uweigand@de.ibm.com>
5738 * dwarf2out.c (gen_decl_die): Handle anonymous struct members.
5740 2004-02-06 Ulrich Weigand <uweigand@de.ibm.com>
5742 * cfganal.c (flow_call_edges_add): Never split a libcall block.
5744 2004-02-06 Daniel Berlin <dberlin@dberlin.org>
5746 * dwarf2out.c (output_loc_list): Don't use deltas if we have
5747 a separate line info table in use.
5748 Use the correct size for terminators.
5749 (output_die): Use offset, not delta.
5751 2004-02-06 H.J. Lu <hongjiu.lu@intel.com>
5753 * doc/invoke.texi: Remove the pni option from -mfpmath=.
5755 2004-02-06 Jan Hubicka <jh@suse.cz>
5757 * recog.c (split_all_insns): Do not update reg info.
5758 * regrename.c (regrename_optimize): Likewise.
5759 * toplev.c (rest_of_handle_reorder_blocks): Likewise.
5760 * flow.c (struct propagate_block_info): Add insn_num field.
5761 (reg_deaths): New array.
5762 (life_analysis): Free reg_deaths info.
5763 (allocate_reg_life_data): Allocate reg_deaths array.
5764 (propagate_one_insn): Use new array.
5765 (init_propagate_block): Initialize it.
5766 (free_propagate_block_info): Finish compuation of
5768 (attempt_auto_inc): Sanity check that REG_INFO is not
5769 computed at same time.
5770 (mark_used_regs): Update new array.
5772 * reg-stack.c (subst_stack_regs): Unshare clobbers before
5775 2004-02-06 Kazu Hirata <kazu@cs.umass.edu>
5777 * config/s390/s390.md (*extendsiqi2_short_displ): Change to
5778 *extendqisi2_short_displ.
5780 2004-02-06 Alan Modra <amodra@bigpond.net.au>
5782 * doc/tm.texi (INIT_CUMULATIVE_ARGS): Update doco.
5783 * calls.c (expand_call): Pass n_named_args to INIT_CUMULATIVE_ARGS.
5784 (emit_library_call_value_1): Likewise pass nargs.
5785 * expr.c (block_move_libcall_safe_for_call_parm): Pass 3 here.
5786 * function.c (assign_parms): Pass -1 to INIT_CUMULATIVE_ARGS.
5787 * config/rs6000/rs6000.c (init_cumulative_args): Use n_named_args
5788 parameter instead of scanning TYPE_ARGS_TYPES to count args.
5789 * config/rs6000/rs6000-protos.h (init_cumulative_args): Update
5791 * config/rs6000/rs6000.h (INIT_CUMULATIVE_ARGS): Pass extra arg.
5792 (INIT_CUMULATIVE_INCOMING_ARGS): Set extra arg to 1000.
5793 (INIT_CUMULATIVE_LIBCALL_ARGS): Set extra arg to 0.
5794 * config/sh/sh.c (sh_output_mi_thunk): Pass 1 as n_named_args to
5795 INIT_CUMULATIVE_ARGS.
5796 * config/alpha/alpha.h (INIT_CUMULATIVE_ARGS): Update.
5797 * config/alpha/unicosmk.h, config/alpha/vms.h, config/arc/arc.h,
5798 config/arm/arm.h, config/avr/avr.h, config/c4x/c4x.h,
5799 config/cris/cris.h, config/fr30/fr30.h, config/frv/frv.h,
5800 config/h8300/h8300.h, config/i386/i386.h, config/i860/i860.h,
5801 config/ia64/ia64.h, config/ip2k/ip2k.h, config/iq2000/iq2000.h,
5802 config/iq2000/iq2000.c, config/m32r/m32r.h, config/m68hc11/m68hc11.h,
5803 config/m68k/m68k.h, config/mcore/mcore.h, config/mips/mips.h,
5804 config/mmix/mmix.h, config/mn10300/mn10300.h, config/ns32k/ns32k.h,
5805 config/pa/pa.h, config/pdp11/pdp11.h, config/s390/s390.h,
5806 config/sh/sh.h, config/sparc/sparc.h, config/stormy16/stormy16.h,
5807 config/v850/v850.h, config/vax/vax.h, config/xtensa/xtensa.h: Likewise.
5809 2004-02-06 Kazu Hirata <kazu@cs.umass.edu>
5811 * genemit.c (gen_exp) [CONST_INT]: Use const_int_rtx whenever
5814 2004-02-06 Kazu Hirata <kazu@cs.umass.edu>
5816 * reload1.c (eliminate_regs_in_insn): If a set has a REG_EQUAL
5817 note containing (plus (reg) (const_int)), where reg is an
5818 eliminable reg, then perform the register elimination without
5819 depending on eliminate_regs().
5821 2004-02-06 Kazu Hirata <kazu@cs.umass.edu>
5823 * config/arc/arc.c (arc_return_in_memory): Check the return
5824 value of int_size_in_bytes against -1. Don't check
5826 * config/avr/avr.c (avr_return_in_memory): Check the return
5827 value of int_size_in_bytes against -1.
5828 * config/ip2k/ip2k.c (ip2k_return_in_memory): Likewise.
5829 * config/m68hc11/m68hc11.c (m68hc11_return_in_memory):
5831 * config/mcore/mcore.c (mcore_return_in_memory): Likewise.
5832 * config/stormy16/stormy16.c (xstormy16_return_in_memory):
5835 2004-02-06 Kazu Hirata <kazu@cs.umass.edu>
5837 * config/frv/frv-protos.h: Remove the prototype for
5838 frv_setup_incoming_varargs.
5839 * config/frv/frv.c (TARGET_SETUP_INCOMING_VARARGS): New.
5840 (frv_setup_incoming_varargs): Make it static.
5841 * config/frv/frv.h (SETUP_INCOMING_VARARGS): Remove.
5843 2004-02-06 Kazu Hirata <kazu@cs.umass.edu>
5845 * config/fr30/fr30-protos.h: Remove the prototype for
5846 fr30_setup_incoming_varargs.
5847 Update the prototypes for fr30_num_arg_regs and
5848 fr30_function_arg_partial_nregs.
5849 * config/fr30/fr30.c (TARGET_STRUCT_VALUE_RTX): New.
5850 (TARGET_SETUP_INCOMING_VARARGS): Likewise.
5851 (fr30_setup_incoming_varargs): Make it static.
5852 Add argument second_time. Don't do anything when second_time
5854 (fr30_num_arg_regs): Change the type of the first argument to
5856 (fr30_function_arg_partial_nregs): Change the type of the
5857 second argument to enum machine_mode.
5858 * config/fr30/fr30.h (STRUCT_VALUE): Remove.
5859 (SETUP_INCOMING_VARARGS): Remove.
5861 2004-02-06 Kazu Hirata <kazu@cs.umass.edu>
5863 * config/arc/arc-protos.h: Remove the prototype for
5864 arc_setup_incoming_varargs.
5865 * config/arc/arc.c (TARGET_ASM_EXTERNAL_LIBCALL): New.
5866 (TARGET_SETUP_INCOMING_VARARGS): Likewise.
5867 (arc_setup_incoming_varargs): Make it static.
5868 (arc_external_libcall): Likewise.
5869 * config/arc/arc.h (SETUP_INCOMING_VARARGS): Remove.
5870 Remove the commented-out definition of
5871 ASM_OUTPUT_EXTERNAL_LIBCALL.
5873 2004-02-05 SUGIOKA Toshinobu <sugioka@itonet.co.jp>
5875 * config/sh/t-linux (SHLIB_INSTALL): Prepend $$(DESTDIR)
5876 to $$(slibdir) in the installation commands.
5878 2004-02-05 David Edelsohn <edelsohn@gnu.org>
5880 * reload.c (refers_to_regno_for_reload_p): Index hard_regno_nregs
5881 with inner_regno, not regno.
5882 * rtlanal.c (refers_to_regno_p): Same.
5884 2004-02-05 Kazu Hirata <kazu@cs.umass.edu>
5886 * config.gcc: Remove i370 support.
5888 2004-02-05 Kelley Cook <kcook@gcc.gnu.org>
5890 * doc/install.texi: Update automake and autoconf version
5891 requirements. Note where to find gcj automake version.
5893 2004-02-05 Kelley Cook <kcook@gcc.gnu.org>
5895 * Makefile.in (generate-manpages): Move dependencies to ...
5897 * doc/makefile.texi: Document new targets.
5898 * doc/sourcebuild.texi (Make-lang.in): Document new langhooks.
5900 2004-02-05 Kelley Cook <kcook@gcc.gnu.org>
5903 Makefile.in (srcextra): Add a level of indirection to ...
5904 (gcc.srcextra): ... here.
5905 (po-generated): Delete.
5906 (po/$(PACKAGE).pot: Use srcextra instead of po-generated. Depend on
5908 (start.encap): Remove superfluous lang.srcextra dependency.
5909 objc/Make-lang.in (po-generated): Delete.
5911 2004-02-05 Kazu Hirata <kazu@cs.umass.edu>
5913 * config/ia64/ia64.c (REG_GP): Remove.
5915 2004-02-05 Rainer Orth <ro@TechFak.Uni-Bielefeld.DE>
5917 * config/mips/iris5gas.h (PREFERRED_DEBUGGING_TYPE): Define.
5919 2004-02-05 Devang Patel <dpatel@apple.com>
5921 * dwarf2out.c (force_type_die): Look up input type itself
5922 instead of root_type() of type.
5924 2004-02-05 Andreas Krebbel <krebbel1@de.ibm.com>
5926 * config/s390/s390.md ("*tmqidi_ext"): New insn.
5927 ("*extendqidi2_short_displ", "*extendsiqi2_short_displ"): Old
5928 pre-reload splitters are transformed to post-reload
5929 define_insn_and_split patterns.
5930 ("*tmqisi_ext"): Renamed old "*tmqi_ext".
5932 2004-02-05 Kazu Hirata <kazu@cs.umass.edu>
5934 * config/cris/cris.h: Replace PROMOTE_PROTOTYPES with
5935 TARGET_PROMOTE_PROTOTYPES.
5937 2004-02-05 Rainer Orth <ro@TechFak.Uni-Bielefeld.DE>
5941 2004-01-15 Geoffrey Keating <geoffk@apple.com>
5943 * c-typeck.c (constructor_asmspec): Delete.
5944 (struct initializer_stack): Delete field 'asmspec'.
5945 (start_init): Delete saving of asmspec.
5946 (finish_init): Don't update constructor_asmspec.
5947 * dwarf2out.c (rtl_for_decl_location): Duplicate string from tree.
5948 * stmt.c (expand_asm): Duplicate strings from tree.
5949 (expand_asm_operands): Likewise.
5950 * tree.c (tree_size): Update computation of size of STRING_CST.
5951 (make_node): Don't make STRING_CST nodes.
5952 (build_string): Allocate string with tree node.
5953 * tree.def (STRING_CST): Update comment.
5954 * tree.h (TREE_STRING_POINTER): Adjust for change to STRING_CST.
5955 (tree_string): Place contents of string in tree node.
5956 * config/sh/sh.c (sh_handle_sp_switch_attribute): Duplicate string
5959 2004-02-05 Joseph S. Myers <jsm@polyomino.org.uk>
5961 * diagnostic.h (DEFINE_DIAGNOSTIC_KIND): Change parameter M to
5964 2004-02-05 Dorit Naishlos <dorit@il.ibm.com>
5966 * config/rs6000/altivec.md (*movv4si_internal): At least one
5967 operand must be altivec_register_operand.
5968 (*movv8hi_internal1): Likewise.
5969 (*movv16qi_internal1): Likewise.
5970 (*movv4sf_internal1): Likewise.
5972 2004-02-05 David Edelsohn <edelsohn@gnu.org>
5974 * configure.ac (gcc_cv_as_powerpc_mfcrf): Correct test for mfcr.
5975 * configure: Regenerate.
5977 2004-02-05 Jonathan Wakely <redi@gcc.gnu.org>
5979 * doc/install.texi: Update description of --gxx-include-dir to
5980 give correct default value.
5982 2004-02-05 Kazu Hirata <kazu@cs.umass.edu>
5984 * config/h8300/h8300.h (REG_OK_FOR_BASE_NONSTRICT_P): Replace
5987 2004-02-05 Kazu Hirata <kazu@cs.umass.edu>
5989 * config/pa/pa.c (emit_hpdiv_const): Replace gen_rtx with
5992 2004-02-05 Kazu Hirata <kazu@cs.umass.edu>
5994 * emit-rtl.c: Update the comment about the file.
5996 2004-02-05 Joseph S. Myers <jsm@polyomino.org.uk>
5998 * sourcebuild.texi (Test Idioms): Update testcase naming
6001 2004-02-04 Per Bothner <per@bothner.com>
6003 Partially revert/redo 2003-10-01 change; fix -fworking-directory.
6004 * c-ppoutput.c (pp_dir_change): New function.
6005 * c-common.h (pp_dir_change): New declaration.
6006 * cpplib.h (struct cpp_options): Remove working_directory field.
6007 * cppinit.c (cpp_find_main_file, cpp_push_main_file): Merge back to
6008 (cpp_read_main_file): as before 10-01. Call _cpp_stack_file.
6009 Don't handle -fworking_directory here, but in c_common_post_options.
6010 (read_original_directory): Don't back up when done.
6011 Don't clear no-longer used working_directory flag.
6012 * cpplib.h: Update declarations to match.
6013 * c-lex.c (cb_dir_change): Move to c-opts.c.
6014 (init_c_lex): Don't set dir_change callback here, since we want
6015 to set it even if flag_preprocess_only.
6016 * c-opts.c (cb_dir_change): Function moved from c-lex.c.
6017 (c_common_post_options): Set dir_change callback.
6018 Call pp_dir_change if approporiate.
6019 (finish_options): Don't call cpp_find_main_file here. Hence remove
6020 unneeded parameter and result. Do LC_RENAME for <built-in>.
6021 (c_common_post_options): Call cpp_read_main_file here instead.
6022 (c_common_init): Update accordingly.
6023 (push_command_line_include): Don't cpp_push_main_file.
6024 Do LC_RENAME rather than LC_LEASE to get back to main file.
6025 Compared to pre-10-01 version, inline cpp_rename_to_main_file.
6026 (c_common_parse_file): Call cpp_read_main_file for subsequent main
6027 files, but call finish_options for all files.
6028 * c-opts.c (sanitize_cpp_opts): Don't set cpp_opts->working_directory.
6029 * fix-header.c (read_scan_file): Call cpp_read_main_file instead of
6030 cpp_find_main_file + cpp_push_main_file.
6031 * c-lex.c (fe_file_change): Don't set main_input_filename here.
6032 * opts.c (handle_options): Only set main_input_filename first time.
6034 2004-02-05 Ian Lance Taylor <ian@wasabisystems.com>
6036 * config/arm/arm.h (REG_CLASS_NAMES): Add missing comma.
6038 2004-02-04 Geoffrey Keating <geoffk@apple.com>
6040 * reload.c (find_equiv_reg): When checking for register overlap,
6041 don't index hard_regno_nregs with a pseudo-reg.
6043 2004-02-04 Ulrich Weigand <uweigand@de.ibm.com>
6045 * config/s390/s390.c (s390_trampoline_template): Remove gen_rtx().
6047 2004-02-04 David Edelsohn <edelsohn@gnu.org>
6049 * reload.c (refers_to_regno_for_reload_p): Test regno, not inner_regno,
6050 against FIRST_PSEUDO_REGISTER.
6052 2004-02-04 Rainer Orth <ro@TechFak.Uni-Bielefeld.DE>
6054 * Makefile.in: Move target, host overrides after per-language
6057 * config/mips/t-iris5-as (FORCE_DEBUG_ADAFLAGS): Clear.
6058 (GNATLIBCFLAGS): Remove -g.
6060 2004-02-04 Kazu Hirata <kazu@cs.umass.edu>
6062 * config/alpha/alpha.c, config/arc/arc.c, config/avr/avr.c,
6063 config/i386/i386.c, config/i386/i386.h, config/i386/i386.md,
6064 config/ia64/ia64.c, config/ia64/unwind-ia64.c,
6065 config/m32r/m32r.c, config/ns32k/ns32k.c, config/pa/pa.c,
6066 config/pdp11/pdp11.c, config/rs6000/rs6000.c,
6067 config/sparc/sparc.c, config/vax/vax.c: Revert the
6068 replacements of "FALLTHRU" with "Fall through" done in the
6071 2004-02-04 Kazu Hirata <kazu@cs.umass.edu>
6073 * config/darwin.c, config/darwin.h, config/freebsd-spec.h,
6074 config/arm/arm.c, config/arm/arm.md,
6075 config/cris/cris-protos.h, config/fr30/fr30.c,
6076 config/fr30/fr30.h, config/h8300/h8300.c, config/i386/i386.h,
6077 config/i860/i860.c, config/i860/i860.h, config/ia64/ia64-c.c,
6078 config/ia64/ia64.c, config/ia64/ia64.h, config/ip2k/ip2k.h,
6079 config/ip2k/ip2k.md, config/ip2k/libgcc.S,
6080 config/m32r/linux.h, config/m32r/m32r.c, config/m32r/m32r.h,
6081 config/m68k/m68k.c, config/m68k/netbsd-elf.h,
6082 config/mips/mips.c, config/mmix/mmix.c, config/mmix/mmix.md,
6083 config/ns32k/netbsd.h, config/ns32k/ns32k.c,
6084 config/ns32k/ns32k.h, config/pdp11/pdp11.h,
6085 config/rs6000/darwin-ldouble.c, config/s390/s390.h,
6086 config/s390/s390.md, config/sparc/netbsd-elf.h,
6087 config/sparc/openbsd.h, config/sparc/sparc.c,
6088 config/xtensa/lib2funcs.S: Fix comment formatting.
6090 2004-02-04 Kazu Hirata <kazu@cs.umass.edu>
6092 * config/alpha/alpha.c, config/arc/arc.c,
6093 config/arm/arm-cores.def, config/arm/arm.c, config/arm/arm.h,
6094 config/arm/arm1026ejs.md, config/arm/arm1136jfs.md,
6095 config/arm/arm926ejs.md, config/arm/vfp.md, config/avr/avr.c,
6096 config/c4x/c4x.c, config/cris/cris.c, config/frv/frv.md,
6097 config/i386/i386.c, config/i386/i386.h, config/i386/i386.md,
6098 config/ia64/ia64.c, config/ia64/unwind-ia64.c,
6099 config/iq2000/iq2000.c, config/m32r/m32r.c,
6100 config/mips/mips.c, config/mmix/mmix.c, config/mmix/mmix.h,
6101 config/ns32k/ns32k.c, config/pa/pa.c, config/pdp11/pdp11.c,
6102 config/rs6000/darwin-ldouble.c, config/rs6000/rs6000.c,
6103 config/rs6000/rs6000.h, config/sparc/sparc.c,
6104 config/vax/vax.c: Fix comment typos. Follow spelling
6107 2004-02-04 Kazu Hirata <kazu@cs.umass.edu>
6109 * alloc-pool.h, c-convert.c, c-lang.c, c-tree.h,
6110 caller-save.c, df.h, genconfig.c, global.c, lcm.c,
6111 ra-rewrite.c, ra.c, regclass.c, regs.h, resource.c,
6112 sched-rgn.c, config/arm/aof.h, config/arm/cirrus.md,
6113 config/arm/fpa.md, config/arm/iwmmxt.md,
6114 config/arm/netbsd-elf.h, config/arm/netbsd.h,
6115 config/m68hc11/m68hc11.md, config/mips/iris5.h,
6116 config/mn10300/mn10300.md, config/rs6000/altivec.md,
6117 config/sparc/netbsd-elf.h: Update copyright.
6119 2004-02-04 Eric Botcazou <ebotcazou@libertysurf.fr>
6121 * config/sparc/sparc.c (function_arg_pass_by_reference): Return 1
6122 for all modes whose size is greater than 8 bytes if ARCH32.
6123 (sparc_va_arg): Handle all modes whose size is greater than 8 bytes
6124 by reference if ARCH32.
6126 2004-02-04 Aldy Hernandez <aldyh@redhat.com>
6128 * cgraphunit.c (cgraph_postorder): Fix typo in comment.
6130 2004-02-04 Ulrich Weigand <uweigand@de.ibm.com>
6132 * config/s390/s390.md ("*la_64" + peepholes, "reload_indi"): Move
6133 to before adddi3 insn patterns.
6134 ("*la_31" + peepholes, "*la_31_and", "*la_31_and_cc", "force_la_31",
6135 "reload_insi"): Move to before addsi3 insn patterns.
6137 2004-02-04 Mark Mitchell <mark@codesourcery.com>
6139 * calls.c (initialize_argument_information): Add CALL_FROM_THUNK_P
6140 parameter. Use it instead of current_function_is_thunk.
6141 * function.h (struct function): Update documentation for is_thunk.
6142 * tree.h (CALL_FROM_THUNK_P): New macro.
6143 * config/alpha/alpha.c (alpha_sa_mask): Do not check
6144 no_new_pseudos when testing current_function_is_thunk.
6145 * config/rs6000/rs6000.c (rs6000_ra_ever_killed): Likeiwse.
6147 2004-02-04 Kazu Hirata <kazu@cs.umass.edu>
6149 * doc/tm.texi: Replace SETUP_INCOMING_VARARGS with
6150 TARGET_SETUP_INCOMING_VARARGS.
6152 2004-02-04 Kazu Hirata <kazu@cs.umass.edu>
6154 * emit-rtl.c (gen_rtx): Remove.
6155 * genattrtab.c: Don't mention gen_rtx in a comment.
6156 * rtl.h: Remove the prototype for gen_rtx.
6157 * doc/md.texi: Replace gen_rtx with gen_rtx_REG.
6159 2004-02-04 Kazu Hirata <kazu@cs.umass.edu>
6161 * config/arc/arc.h, config/fr30/fr30.h
6162 (SETUP_INCOMING_VARARGS): Remove the target-independent
6164 * doc/tm.texi: Don't mention deprecated target macros.
6166 2004-02-04 Kazu Hirata <kazu@cs.umass.edu>
6168 * config/fr30/fr30.h (FUNCTION_VALUE): Remove the
6169 target-independent comment.
6171 2004-02-04 Kazu Hirata <kazu@cs.umass.edu>
6173 * doc/interface.texi, doc/tm.texi, doc/trouble.texi: Don't
6174 mention deprecated target macros.
6176 2004-02-04 Kazu Hirata <kazu@cs.umass.edu>
6178 * config.gcc: Remove obsolete ports and configurations.
6179 * config/linux-aout.h, config/netware.h,
6180 config/t-linux-gnulibc1, config/d30v/abi,
6181 config/d30v/d30v-protos.h, config/d30v/d30v.c,
6182 config/d30v/d30v.h, config/d30v/d30v.md,
6183 config/d30v/libgcc1.asm, config/d30v/t-d30v,
6184 config/dsp16xx/dsp16xx-modes.def,
6185 config/dsp16xx/dsp16xx-protos.h, config/dsp16xx/dsp16xx.c,
6186 config/dsp16xx/dsp16xx.h, config/dsp16xx/dsp16xx.md,
6187 config/i370/README, config/i370/i370-c.c,
6188 config/i370/i370-protos.h, config/i370/i370.c,
6189 config/i370/i370.h, config/i370/i370.md, config/i370/linux.h,
6190 config/i370/mvs.h, config/i370/oe.h, config/i370/t-i370,
6191 config/i386/freebsd-aout.h, config/i386/linux-aout.h,
6192 config/i386/moss.h, config/i386/netware.h,
6193 config/i386/svr3.ifile, config/i386/svr3dbx.h,
6194 config/i386/svr3gas.h, config/i386/svr3z.ifile,
6195 config/i386/t-udk, config/i386/udk.h, config/i386/vsta.h,
6196 config/i960/i960-c.c, config/i960/i960-coff.h,
6197 config/i960/i960-modes.def, config/i960/i960-protos.h,
6198 config/i960/i960.c, config/i960/i960.h, config/i960/i960.md,
6199 config/i960/rtems.h, config/i960/t-960bare,
6200 config/m68k/hp310.h, config/m68k/hp320.h,
6201 config/m68k/hp320base.h, config/m68k/m68kv4.h,
6202 config/m68k/netbsd.h, config/m68k/sgs.h, config/m68k/t-hp320:
6204 * doc/extend.texi, doc/install.texi, doc/invoke.texi,
6205 doc/md.texi: Remove mentions of obsolete ports.
6207 2004-02-04 Jan Hubicka <jh@suse.cz>
6209 * alias.c (find_base_term, get_addr): Do not dereference NULL
6210 pointer when all VALUE's locations has been invalidated.
6211 (rtx_equal_for_memref_p): Simplify checking of VALUEs.
6213 2004-02-03 Wolfgang Bangerth <bangerth@dealii.org>
6215 * doc/invoke.texi (x86 options): Fix spelling/wording.
6217 2004-02-03 Richard Sandiford <rsandifo@redhat.com>
6219 * config/mips/iris5.h (ASM_OUTPUT_ASCII): Use mips_output_ascii to
6220 put the original string in a comment.
6221 * config/mips/mips-protos.h (mips_output_ascii): Add prefix argument.
6222 * config/mips/mips.c (mips_output_ascii): Likewise.
6223 * config/mips/mips.h (ASM_OUTPUT_ASCII): Adjust accordingly.
6225 2004-02-03 Kazu Hirata <kazu@cs.umass.edu>
6227 * system.h (GIV_SORT_CRITERION): Poison.
6228 * config/avr/avr.h (GIV_SORT_CRITERION): Remove.
6229 * config/ip2k/ip2k.h (GIV_SORT_CRITERION): Likewise.
6231 2004-02-03 Roger Sayle <roger@eyesopen.com>
6234 * expr.c (expand_expr_real) <MULT_EXPR>: When performing widening
6235 multiplies with a multiplication of the wrong signedness, its the
6236 signedness of the multiplication that we've performed that needs to
6237 be passed to expand_mult_highpart_adjust. Avoid emitting a nop-move
6238 if expand_mult_highpart_adjust places the result in target.
6240 2004-02-03 Richard Henderson <rth@redhat.com>
6242 * varasm.c (const_desc_rtx_sym_eq): Compare symbol strings.
6244 2004-02-03 J"orn Rennecke <joern.rennecke@superh.com>
6246 * config.gcc (sh[234]l): Use little endian fragments.
6248 2004-02-03 Paul Koning <pkoning@equallogic.com>
6250 * config/pdp11/pdp11-modes.def: Add RESET_FLOAT_FORMAT calls.
6251 * config/pdp11/pdp11-protos.h (legitimate_const_double_p): Add.
6252 * config/pdp11/pdp11.c (encode_pdp11_f, decode_pdp11_f,
6253 encode_pdp11_d, decode_pdp11_d): New functions to handle PDP11
6254 floating point format.
6255 (pdp11_f_format, pdp11_d_format): New real_format descriptors for
6256 the above functions.
6257 (output_move_quad): Output float values in correct target format.
6258 (legitimate_const_double_p): New function.
6259 * config/pdp11/pdp11.h: Fix typos.
6260 (FLOAT_WORDS_BIG_ENDIAN): Add definition.
6261 (TARGET_FLOAT_FORMAT): Ditto.
6262 (pdp11_f_format, pdp11_d_format): Add external declarations.
6263 (MAX_REGS_PER_ADDRESS): Corrected.
6264 (LEGITIMATE_CONSTANT_P): Use legitimate_const_double_p().
6265 (PRINT_OPERAND): Output float literals in target format.
6267 2004-02-03 Mark Mitchell <mark@codesourcery.com>
6270 * tree.h (enum tree_index): Add TI_PUBLIC, TI_PROTECTED, and
6272 (access_public_node): Redefine.
6273 (access_protected_node): Likewise.
6274 (access_private_node): Likewise.
6275 * tree.c (build_common_tree_nodes): Create access_public_node,
6276 access_protected_node, and access_private_node.
6278 2004-02-03 Steve Ellcey <sje@cup.hp.com>
6280 * config/ia64/ia64.h (MASK_INLINE_INT_DIV_LAT): Change value.
6281 (MASK_INLINE_INT_DIV_THR): Ditto.
6282 (MASK_INLINE_SQRT_LAT): Ditto.
6283 (MASK_INLINE_SQRT_THR): Ditto.
6284 (MASK_DWARF2_ASM): Ditto.
6285 (MASK_EARLY_STOP_BITS): Ditto.
6287 2004-02-02 Paul Brook <paul@codesourcery.com>
6289 Merge from csl-arm-branch.
6291 2004-01-30 Paul Brook <paul@codesourcery.com>
6293 * aof.h (REGISTER_NAMES): Add vfp reg names
6294 (ADDITIONAL_REGISTER_NAMES): Ditto.
6295 * aout.h (REGISTER_NAMES): Ditto.
6296 (ADDITIONAL_REGISTER_NAMES): Ditto.
6297 * arm-protos.h: Update/Add Prototypes.
6298 * arm.c (init_fp_table): Rename from init_fpa_table. Update users.
6299 Only allow 0.0 for VFP.
6300 (fp_consts_inited): Rename from fpa_consts_inited. Update users.
6301 (values_fp): Rename from values_fpa. Update Users.
6302 (arm_const_double_rtx): Rename from const_double_rtx_ok_for_fpa.
6303 Update users. Only check valid constants for this hardware.
6304 (arm_float_rhs_operand): Rename from fpa_rhs_operand. Update Users.
6305 Only allow consts for FPA.
6306 (arm_float_add_operand): Rename from fpa_add_operand. Update users.
6307 Only allow consts for FPA.
6308 (use_return_insn): Check for saved VFP regs.
6309 (arm_legitimate_address_p): Handle VFP DFmode addressing.
6310 (arm_legitimize_address): Ditto.
6311 (arm_general_register_operand): New function.
6312 (vfp_mem_operand): New function.
6313 (vfp_compare_operand): New function.
6314 (vfp_secondary_reload_class): New function.
6315 (arm_float_compare_operand): New function.
6316 (vfp_print_multi): New function.
6317 (vfp_output_fstmx): New function.
6318 (vfp_emit_fstm): New function.
6319 (arm_output_epilogue): Output VPF reg restore code.
6320 (arm_expand_prologue): Output VFP reg save code.
6321 (arm_print_operand): Add 'P'.
6322 (arm_hard_regno_mode_ok): Return modes for VFP regs.
6323 (arm_regno_class): Return classes for VFP regs.
6324 (arm_compute_initial_elimination_offset): Include space for VFP regs.
6325 (arm_get_frame_size): Ditto.
6326 * arm.h (FIXED_REGISTERS): Add VFP regs.
6327 (CALL_USED_REGISTERS): Ditto.
6328 (CONDITIONAL_REGISTER_USAGE): Enable VFP regs.
6329 (FIRST_VFP_REGNUM): Define.
6330 (LAST_VFP_REGNUM): Define.
6331 (IS_VFP_REGNUM): Define.
6332 (FIRST_PSEUDO_REGISTER): Include VFP regs.
6333 (HARD_REGNO_NREGS): Handle VFP regs.
6334 (REG_ALLOC_ORDER): Add VFP regs.
6335 (enum reg_class): Add VFP_REGS.
6336 (REG_CLASS_NAMES): Ditto.
6337 (REG_CLASS_CONTENTS): Ditto.
6338 (CANNOT_CHANGE_MODE_CLASS) Handle VFP Regs.
6339 (REG_CLASS_FROM_LETTER): Add 'w'.
6340 (EXTRA_CONSTRAINT_ARM): Add 'U'.
6341 (EXTRA_MEMORY_CONSTRAINT): Define.
6342 (SECONDARY_OUTPUT_RELOAD_CLASS): Handle VFP regs.
6343 (SECONDARY_INPUT_RELOAD_CLASS): Ditto.
6344 (REGISTER_MOVE_COST): Ditto.
6345 (PREDICATE_CODES): Add arm_general_register_operand,
6346 arm_float_compare_operand and vfp_compare_operand.
6347 * arm.md (various): Rename as above.
6348 (divsf3): Enable when TARGET_VFP.
6353 (arm_movdi): Disable when TARGET_VFP.
6354 (arm_movsi_insn): Ditto.
6355 (movsi): Only split with general regs.
6356 (cmpsf): Use arm_float_compare_operand.
6357 (push_fp_multi): Restrict to TARGET_FPA.
6360 * fpa.md (various): Rename as above.
6361 * doc/md.texi: Document ARM w and U constraints.
6363 2004-01-15 Paul Brook <paul@codesourcery.com>
6365 * config.gcc: Add with_fpu. Allow with-float=softfp.
6366 * config/arm/arm.c (arm_override_options): Rename *-s to *s.
6367 Break out of loop when we find a float-abi. Fix typo.
6368 * config/arm/arm.h (OPTION_DEFAULT_SPECS): Add "fpu".
6370 * doc/install.texi: Document --with-fpu.
6372 2003-01-14 Paul Brook <paul@codesourcery.com>
6374 * config.gcc (with_arch): Add armv6.
6375 * config/arm/arm.h: Rename TARGET_CPU_*_s to TARGET_CPU_*s.
6376 * config/arm/arm.c (arm_overrride_options): Ditto.
6378 2004-01-08 Richard Earnshaw <rearnsha@arm.com>
6380 * arm.c (FL_ARCH3M): Renamed from FL_FAST_MULT.
6381 (FL_ARCH6): Renamed from FL_ARCH6J.
6382 (arm_arch3m): Renamed from arm_fast_multiply.
6383 (arm_arch6): Renamed from arm_arch6j.
6384 * arm.h: Update all uses of above.
6385 * arm-cores.def: Likewise.
6388 * arm.h (CPP_CPU_ARCH_SPEC): Emit __ARM_ARCH_6J__ define for armV6j,
6389 not arm6j. Add entry for arch armv6.
6391 2004-01-07 Richard Earnshaw <rearnsha@arm.com>
6393 * arm.c (arm_emit_extendsi): Delete.
6394 * arm-protos.h (arm_emit_extendsi): Delete.
6395 * arm.md (zero_extendhisi2): Also handle zero-extension of
6397 (zero_extendqisi2, extendhisi2, extendqisi2): Likewise.
6398 (thumb_zero_extendhisi2): Only match if not v6.
6399 (arm_zero_extendhisi2, thumb_zero_extendqisi2, arm_zero_extendqisi2)
6400 (thumb_extendhisi2, arm_extendhisi2, arm_extendqisi)
6401 (thumb_extendqisi2): Likewise.
6402 (thumb_zero_extendhisi2_v6, arm_zero_extendhisi2_v6): New patterns.
6403 (thumb_zero_extendqisi2_v6, arm_zero_extendqisi2_v6): New patterns.
6404 (thumb_extendhisi2_insn_v6, arm_extendhisi2_v6): New patterns.
6405 (thumb_extendqisi2_v6, arm_extendqisi_v6): New patterns.
6406 (arm_zero_extendhisi2_reg, arm_zero_extendqisi2_reg): Delete.
6407 (arm_extendhisi2_reg, arm_extendqisi2_reg): Delete.
6408 (arm_zero_extendhisi2addsi): Remove subreg. Add attributes.
6409 (arm_zero_extendqisi2addsi, arm_extendhisi2addsi): Likewise.
6410 (arm_extendqisi2addsi): Likewise.
6412 2003-12-31 Mark Mitchell <mark@codesourcery.com>
6415 * config/arm/arm.h (THUMB_LEGTITIMIZE_RELOAD_ADDRESS): Reload REG
6416 + REG addressing modes.
6418 * config/arm/arm.h (THUMB_LEGTITIMIZE_RELOAD_ADDRESS): Reload REG
6419 + REG addressing modes.
6421 2003-12-30 Mark Mitchell <mark@codesourcery.com>
6423 * config/arm/arm.h (THUMB_LEGITIMATE_CONSTANT_P): Accept
6426 2003-30-12 Paul Brook <paul@codesourcery.com>
6428 * longlong.h: protect arm inlines with !defined (__thumb__)
6430 2003-30-12 Paul Brook <paul@codesourcery.com>
6432 * config/arm/arm.h (TARGET_CPU_CPP_BUILTINS): Always define __arm__.
6434 2003-12-30 Nathan Sidwell <nathan@codesourcery.com>
6436 * builtins.c (expand_builtin_apply_args_1): Fix typo in previous
6439 2003-12-29 Nathan Sidwell <nathan@codesourcery.com>
6441 * builtins.c (expand_builtin_apply_args_1): Add pretend args size
6442 to the virtual incoming args pointer for downward stacks.
6444 2003-12-29 Paul Brook <paul@codesourcery.com>
6446 * config/arm/arm-cores.def: Add cost function.
6447 * config/arm/arm.c (arm_*_rtx_costs): New functions.
6448 (arm_rtx_costs): Remove
6449 (struct processors): Add rtx_costs field.
6450 (all_cores, all_architectures): Ditto.
6451 (arm_override_options): Set targetm.rtx_costs.
6452 (thumb_rtx_costs): New function.
6453 (arm_rtx_costs_1): Remove cases handled elsewhere.
6454 * config/arm/arm.h (processor_type): Add COSTS parameter.
6456 2003-12-29 Nathan Sidwell <nathan@codesourcery.com>
6458 * config/arm/arm.md (generic_sched): arm926 has its own scheduler.
6459 (arm926ejs.md): Include it.
6460 * config/arm/arm926ejs.md: New pipeline description.
6462 2003-12-24 Paul Brook <paul@codesourcery.com>
6464 * config/arm/arm.c (arm_arch6j): New variable.
6465 (arm_override_options): Set it.
6466 (arm_emit_extendsi): New function.
6467 * config/arm/arm-protos.h (arm_emit_extendsi): Add prototype.
6468 * config/arm/arm.h (arm_arch6j): Declare.
6469 * config/arm/arm.md: Add sign/zero extend insns.
6471 2003-12-23 Paul Brook <paul@codesourcery.com>
6473 * config/arm/arm.c (all_architectures): Add armv6.
6474 * doc/invoke.texi: Document it.
6476 2003-12-19 Paul Brook <paul@codesourcery.com>
6478 * config/arm/arm.md: Add load1 and load_byte "type" attrs. Modify
6479 insn patterns to match.
6480 * config/arm/arm-generic.md: Ditto.
6481 * config/arm/cirrus.md: Ditto.
6482 * config/arm/fpa.md: Ditto.
6483 * config/amm/iwmmxt.md: Ditto.
6484 * config/arm/arm1026ejs.md: Ditto.
6485 * config/arm/arm1135jfs.md: Ditto. Add insn_reservation and bypasses
6488 2003-12-18 Nathan Sidwell <nathan@codesourcery.com>
6490 * config/arm/arm-protos.h (arm_no_early_alu_shift_value_dep): Declare.
6491 * config/arm/arm.c (arm_adjust_cost): Check shift cost for
6492 TYPE_ALU_SHIFT and TYPE_ALU_SHIFT_REG.
6493 (arm_no_early_store_addr_dep, arm_no_early_alu_shift_dep,
6494 arm_no_early_mul_dep): Correctly deal with conditional execution,
6495 parallels and single shift operations.
6496 (arm_no_early_alu_shift_value_dep): Define.
6497 * arm.md (attr type): Replace 'normal' with 'alu',
6498 'alu_shift' and 'alu_shift_reg'.
6499 (attr core_cycles): Adjust.
6500 (*addsi3_carryin_shift, andsi_not_shiftsi_si, *arm_shiftsi3,
6501 *shiftsi3_compare0, *notsi_shiftsi, *notsi_shiftsi_compare0,
6502 *not_shiftsi_compare0_scratch, *cmpsi_shiftsi, *cmpsi_shiftsi_swp,
6503 *cmpsi_neg_shiftsi, *arith_shiftsi, *arith_shiftsi_compare0,
6504 *arith_shiftsi_compare0_scratch, *sub_shiftsi,
6505 *sub_shiftsi_compare0, *sub_shiftsi_compare0_scratch,
6506 *if_shift_move, *if_move_shift, *if_shift_shift): Set type
6507 attribute appropriately.
6508 * config/arm/arm1026ejs.md (alu_op): Adjust.
6509 (alu_shift_op, alu_shift_reg_op): New.
6510 * config/arm/arm1136.md: Add better bypasses for early
6511 registers. Remove load[234] and store[234] bypasses.
6512 (11_alu_op): Adjust.
6513 (11_alu_shift_op, 11_alu_shift_reg_op): New.
6515 2003-12-15 Nathan Sidwell <nathan@codesourcery.com>
6517 * config/arm/arm-protos.h (arm_no_early_store_addr_dep,
6518 arm_no_early_alu_shift_dep, arm_no_early_mul_dep): Declare.
6519 * config/arm/arm.c (arm_no_early_store_addr_dep,
6520 arm_no_early_alu_shift_dep, arm_no_early_mul_dep): Define.
6521 * config/arm/arm1026ejs.md: Add load-store bypass.
6522 * config/arm/arm1136jfs.md (11_alu_op): Take 2 cycles.
6523 Add bypasses between instructions.
6525 2003-12-10 Paul Brook <paul@codesourcery.com>
6527 * config/arm/arm.c (arm_fpu_model): New variable.
6528 (arm_fload_abi): New variable.
6529 (target_fpe_name): Rename from target_fp_name.
6530 (target_fpu_name): New variable.
6531 (arm_is_cirrus): Remove.
6532 (fpu_desc): New struct.
6534 (pf_model_for_fpu): Define.
6535 (all_loat_abis): Define.
6536 (arm_override_options): Set fp arch flags based on -mfpu=
6538 (FIRST_FPA_REGNUM): Rename from FIRST_ARM_FP_REGNUM.
6539 (LAST_FPA_REGNUM): Rename from LAST_ARM_FP_REGNUM.
6540 (*): Use new TARGET_* flags.
6541 * config/arm/arm.h (TARGET_ANY_HARD_FLOAT): Remove.
6542 (TARGET_HARD_FLOAT): No longer implies TARGET_FPA.
6543 (TARGET_SOFT_FLOAT): Ditto.
6544 (TARGET_SOFT_FLOAT_ABI): New.
6545 (TARGET_MAVERICK): Rename from TARGET_CIRRUS. No longer implies
6547 (TARGET_VFP): No longer implies TARGET_HARD_FLOAT.
6548 (TARGET_OPTIONS): Add -mfpu=.
6549 (FIRST_FPA_REGNUM): Rename from FIRST_ARM_FP_REGNUM.
6550 (LAST_FPA_REGNUM): Rename from LAST_ARM_FP_REGNUM.
6551 (arm_pf_model): Define.
6552 (arm_float_abi_type): Define.
6553 (fputype): Add FPUTYPE_VFP. Change SOFT_FPA->NONE
6554 * config/arm/arm.md: Use new TARGET_* flags.
6555 * config/arm/cirrus.md: Ditto.
6556 * config/arm/fpa.md: Ditto.
6557 * config/arm/elf.h (ASM_SPEC): Pass -mfloat-abi= and -mfpu=.
6558 * config/arm/semi.h (ASM_SPEC): Ditto.
6559 * config/arm/netbsd-elf.h (SUBTARGET_ASM_FLOAT_SPEC): Specify vfp.
6560 (FPUTYPE_DEFAULT): Set to VFP.
6561 * doc/invoke.texi: Document -mfpu= and -mfloat-abi=.
6563 2003-11-22 Phil Edwards <phil@codesourcery.com>
6566 * config/arm/arm.c (arm_output_mi_thunk): In Thumb mode, use
6567 'bx' instead of 'b' to avoid branch range restrictions. Output
6568 the thunk immediately before the thunked-to function.
6569 * config/arm/arm.h (ARM_DECLARE_FUNCTION_NAME): Do not emit
6570 .thumb_func if a thunk is being generated. Emit .code 16 along
6571 with .thumb_func if a thunk is not being generated.
6573 2003-11-15 Nicolas Pitre <nico@cam.org>
6575 * config/arm/arm.md (ashldi3, arm_ashldi3_1bit, ashrdi3,
6576 arm_ashrdi3_1bit, lshrdi3, arm_lshrdi3_1bit): New patterns.
6577 * config/arm/iwmmxt.md (ashrdi3_iwmmxt): Renamed from ashrdi3.
6578 (lshrdi3_iwmmxt): Renamed from lshrdi3.
6579 * config/arm/arm.c (IWMMXT_BUILTIN2): Renamed argument accordingly.
6581 2003-11-12 Steve Woodford <scw@wasabisystems.com>
6582 Ian Lance Taylor <ian@wasabisystems.com>
6584 * config/arm/lib1funcs.asm (ARM_DIV_BODY, ARM_MOD_BODY): Add new
6585 code for __ARM_ARCH__ >= 5 && ! defined (__OPTIMIZE_SIZE__).
6587 2003-11-05 Phil Edwards <phil@codesourcery.com>
6589 * config/arm/arm.md (insn): Add new V6 instruction names.
6590 (generic_sched): New attr.
6591 * config/arm/arm-generic.md: Use generic_sched here.
6592 * config/arm/arm1026ejs.md: Do not model fetch/issue/decode
6593 stages of pipeline. Adjust latency counts accordingly.
6594 * config/arm/arm1136jfs.md: New file.
6596 2003-10-28 Mark Mitchell <mark@codesourcery.com>
6598 * config/arm/arm.h (processor_type): New enumeration type.
6599 (CPP_ARCH_DEFAULT_SPEC): Set appropriately for ARM 926EJ-S,
6600 ARM1026EJ-S, ARM1136J-S, and ARM1136JF-S processor cores.
6601 (CPP_CPU_ARCH_SPEC): Likewise.
6602 * config/arm/arm.c (arm_tune): New variable.
6603 (all_cores): Use cores.def.
6604 (all_architectures): Add representative processor.
6605 (arm_override_options): Restructure way in which tuning
6606 information is deduced.
6607 * arm.md: Update "insn" and "type" attributes throughout.
6608 (insn): New attribute.
6609 (type): Compute "mult" from "insn" attribute. Add load2,
6610 load3, load4 alternatives.
6611 (arm automaton): Move to arm-generic.md.
6612 * config/arm/arm-cores.def: New file.
6613 * config/arm/arm-generic.md: Likewise.
6614 * config/arm/arm1026ejs.md: Likewise.
6616 2004-02-03 Eric Botcazou <ebotcazou@libertysurf.fr>
6618 * doc/invoke.texi (SPARC options): Remove -mflat and
6619 all -mxxx (xxx:chip) options.
6620 * config/sparc/aout.h (DBX_REGISTER_NUMBER): Delete.
6621 * config/sparc/litecoff.h (DBX_REGISTER_NUMBER): Likewise.
6622 * config/sparc/netbsd-elf.h (DBX_REGISTER_NUMBER): Likewise.
6623 * config/sparc/sol2.h (DBX_REGISTER_NUMBER): Likewise.
6624 * config/sparc/sparc-protos.h: Delete sparc_flat_* prototypes.
6625 * config/sparc/sparc.c: Likewise.
6626 (sparc_output_function_prologue): Remove TARGET_FLAT handling.
6627 (sparc_nonflat_function_prologue): Rename into sparc_function_prologue.
6628 (sparc_output_function_epilogue): Remove TARGET_FLAT handling.
6629 (sparc_nonflat_function_epilogue): Rename into sparc_function_epilogue.
6630 (struct sparc_frame_info, current_frame_info, zero_frame_info): Delete.
6631 (sparc_flat_must_save_register_p): Likewise.
6632 (sparc_flat_compute_frame_size): Likewise.
6633 (sparc_flat_save_restore): Likewise.
6634 (sparc_flat_function_prologue): Likewise.
6635 (sparc_flat_function_epilogue): Likewise.
6636 (sparc_flat_epilogue_delay_slots): Likewise.
6637 (sparc_flat_eligible_for_epilogue_delay): Likewise.
6638 (sparc_function_ok_for_sibcall): Remove TARGET_FLAT handling.
6639 * config/sparc/sparc.h (MASK_FLAT, TARGET_FLAT): Delete.
6640 (TARGET_SWITCHES): Remove -mflat and all -mxxx (xxx:chip) options.
6641 (SPARC_INCOMING_INT_ARG_FIRST): Remove TARGET_FLAT handling.
6642 (CONDITIONAL_REGISTER_USAGE): Likewise.
6643 (FRAME_POINTER_REQUIRED): Likewise.
6644 (INITIAL_ELIMINATION_OFFSET): Likewise.
6645 (BASE_RETURN_VALUE_REG): Likewise.
6646 (BASE_OUTGOING_VALUE_REG): Likewise.
6647 (BASE_PASSING_ARG_REG): Likewise.
6648 (BASE_INCOMING_ARG_REG): Likewise.
6649 (INCOMING_REGNO): Likewise.
6650 (OUTGOING_REGNO): Likewise.
6651 (LOCAL_REGNO): Likewise.
6652 (DELAY_SLOTS_FOR_EPILOGUE): Likewise.
6653 (ELIGIBLE_FOR_EPILOGUE_DELAY): Likewise.
6654 (EPILOGUE_USES): Likewise.
6655 * config/sparc/sparc.md ("isa" attribute): Change "v6" into "v7".
6656 ("flat" attribute): Delete.
6657 (do_builtin_setjmp_setup): Remove TARGET_FLAT and "flat" attribute
6659 (call followed by jump define_peephole's): Delete.
6660 (exception_receiver): Likewise.
6661 (builtin_setjmp_receiver): Likewise.
6662 * config/sparc/t-sparclite (MULTILIB_OPTIONS): Remove -mflat.
6664 2004-02-03 Paolo Bonzini <bonzini@gnu.org>
6668 * Makefile.in (c-parse.o, c-convert.o, c-typeck.o): Depend
6670 * objc/Make-lang.in (objc-parse.o): Depend on langhooks.h.
6671 * c-parse.in, c-convert.c, c-typeck.c, objc/objc-act.c:
6672 Include langhooks.h. Replace c_common_truthvalue_conversion
6673 with the truthvalue_conversion language hook throughout.
6674 (expr_no_commas): Call default_conversion before save_expr
6675 for the first term of the production 'x ? : y'.
6676 * c-common.c (c_common_truthvalue_conversion): Remove
6677 obsolete block. Invoke recursively the hook instead
6679 * c-convert.c (convert): handle ERROR_MARK_NODE.
6680 * c-typeck.c (build_binary_op): handle ERROR_MARK_NODE
6681 returned by the truthvalue_conversion language hook.
6682 * c-lang.c (LANG_HOOKS_TRUTHVALUE_CONVERSION): Use
6683 c_objc_common_truthvalue_conversion.
6684 * c-objc-common.c (c_objc_common_truthvalue_conversion):
6686 * c-tree.h (c_objc_common_truthvalue_conversion): Declare it.
6687 * objc/objc-lang.c (LANG_HOOKS_TRUTHVALUE_CONVERSION): Use
6688 c_objc_common_truthvalue_conversion.
6690 2004-02-03 Kazu Hirata <kazu@cs.umass.edu>
6692 * config/c4x/c4x.h (FUNCTION_VALUE): Use gen_rtx_REG instead
6694 (LIBCALL_VALUE): Likewise.
6695 * config/ip2k/ip2k.c (mdr_try_propagate_clr_sequence): Use
6696 gen_rtx_CC0 instead of gen_rtx.
6697 * config/m68hc11/m68hc11.c (m68hc11_emit_libcall): Use
6698 gen_rtx_fmt_e and gen_rtx_fmt_ee instead of gen_rtx.
6699 (m68hc11_expand_compare): Use gen_rtx_fmt_ee instead of
6701 (m68hc11_emit_logical): Likewise.
6703 2004-02-03 Kazu Hirata <kazu@cs.umass.edu>
6705 * config/alpha/alpha.c, config/arm/arm.c, config/c4x/c4x.c,
6706 config/fr30/fr30.md, config/frv/frv.c, config/frv/frv.md,
6707 config/h8300/h8300.c, config/ia64/ia64.c, config/ip2k/ip2k.md,
6708 config/m32r/m32r.md, config/m68hc11/m68hc11.c,
6709 config/mips/mips.md, config/mmix/mmix.c,
6710 config/mn10300/mn10300.c, config/mn10300/mn10300.md,
6711 config/ns32k/ns32k.c, config/pa/pa.md, config/pdp11/pdp11.c,
6712 config/rs6000/altivec.md, config/s390/s390.c,
6713 config/s390/s390.h, config/s390/s390.md, config/sh/sh.c,
6714 config/sh/sh.h, config/sh/sh.md, config/stormy16/stormy16.c:
6715 Use const0_rtx instead of GEN_INT (0). Do the same for other
6716 constants that are readily available.
6718 2004-02-03 Kazu Hirata <kazu@cs.umass.edu>
6720 * doloop.c, optabs.c, regmove.c, sched-deps.c,
6721 config/i386/i386.c, config/i386/i386.md: Use const0_rtx
6722 instead of GEN_INT (0). Do the same for other constants that
6723 are readily available.
6725 2004-02-03 Kazu Hirata <kazu@cs.umass.edu>
6727 * combine.c (simplify_set): Use gen_rtx_fmt_e instead of
6729 * emit-rtl.c (init_emit_once): Use gen_rtx_PC and gen_rtx_CC0
6731 * reload1.c (init_elim_table): Use gen_rtx_fmt_e instead of
6733 * config/ns32k/ns32k.md (udivmodhi4): Use gen_rtx_IOR and
6734 gen_rtx_ASHIFT instead of gen_rtx.
6735 (udivmodqi4): Likewise.
6737 2004-02-02 Richard Henderson <rth@redhat.com>
6740 * expr.c (store_expr): Use force_operand before emit_move_insn.
6742 2004-02-02 Jeff Law <law@redhat.com>
6743 Roger Sayle <roger@eyesopen.com>
6745 * tree.c (commutative_tree_code, associative_tree_code): New
6747 (iterative_hash_expr): Use commutative_tree_code.
6748 * tree.h (commutative_tree_code, associative_tree_code): Declare.
6749 * fold-const.c (operand_equal_p): Use commutative_tree_code
6750 rather than inlining the commutativity check.
6753 2004-02-02 Kazu Hirata <kazu@cs.umass.edu>
6755 * system.h (FUNCTION_ARG_KEEP_AS_REFERENCE): Poison.
6756 * config/frv/frv-protos.h: Remove the prototype for
6757 frv_function_arg_keep_as_reference.
6758 * config/frv/frv.c (frv_function_arg_keep_as_reference):
6760 * config/frv/frv.h (FUNCTION_ARG_KEEP_AS_REFERENCE): Likewise.
6761 * config/stormy16/stormy16.h: Remove the commented-out
6762 definition of FUNCTION_ARG_KEEP_AS_REFERENCE.
6764 2004-02-03 Alan Modra <amodra@bigpond.net.au>
6767 * config/rs6000/linux64.h (MD_FALLBACK_FRAME_STATE_FOR): Use ap
6770 2004-02-02 Kazu Hirata <kazu@cs.umass.edu>
6772 * genemit.c (gen_exp): Generate gen_rtx_fmt_e* instead of
6775 2004-02-02 Eric Christopher <echristo@redhat.com>
6776 Zack Weinberg <zack@codesourcery.com>
6778 * c-opts.c (c_common_handle_option): Add -finput-charset.
6780 * cppcharset.c (one_iso88591_to_utf8): Remove.
6781 (convert_iso88591_utf8): Ditto.
6782 (conversion_tab): Remove 8859-1 converter.
6783 (_cpp_input_to_utf8): Remove.
6784 (_cpp_init_iconv_buffer): Ditto.
6785 (_cpp_close_iconv_buffer): Ditto.
6786 (_cpp_convert_input): New function.
6787 (_cpp_default_encoding): Ditto.
6788 * cpphash.h: Add/remove prototypes for above.
6789 * cppfiles.c (read_file_guts): Use _cpp_convert_input.
6790 * cppinit.c (cpp_create_reader): Use _cpp_default_encoding
6791 for narrow execution and input character sets.
6792 * cpplib.c (cpp_push_buffer): Delete uses of removed functions.
6793 * doc/cppopts.texi: Document -finput-charset.
6795 2004-02-02 David Edelsohn <edelsohn@gnu.org>
6797 * rtlanal.c (refers_to_regno_p): Test regno, not inner_regno,
6798 against FIRST_PSEUDO_REGISTER.
6800 2004-02-02 Eric Botcazou <ebotcazou@libertysurf.fr>
6802 * doc/invoke.texi (SPARC options): Further improve.
6804 2004-02-02 Kazu Hirata <kazu@cs.umass.edu>
6806 * config/arm/arm.md, config/c4x/c4x.md, config/cris/cris.md,
6807 config/h8300/h8300.c, config/ip2k/ip2k.md,
6808 config/iq2000/iq2000.c, config/mips/mips.c,
6809 config/rs6000/rs6000.c, config/rs6000/rs6000.md,
6810 config/sh/sh.c, config/sh/sh.md, config/stormy16/stormy16.c,
6811 config/v850/v850.md: Fix indentation.
6813 2004-02-02 Eric Botcazou <ebotcazou@libertysurf.fr>
6815 * config/sparc/sparc.c (function_arg_slotno): Align TImode
6816 arguments on a 16-byte boundary in the parameter array if ARCH64.
6817 Split handling of TFmode.
6819 2004-02-02 Paolo Bonzini <bonzini@gnu.org>
6821 * rtlanal.c (reg_overlap_mentioned_p) [!ENABLE_CHECKING]:
6822 Don't test CONSTANT_P (x).
6823 (reg_overlap_mentioned_p): Merge check for STRICT_LOWPART,
6824 ZERO_EXTRACT, SIGN_EXTRACT with the switch statement.
6827 2004-02-02 Eric Botcazou <ebotcazou@libertysurf.fr>
6829 * doc/invoke.texi (SPARC options): Document that -mflat is deprecated.
6831 2004-02-02 Kazu Hirata <kazu@cs.umass.edu>
6833 * config/arc/arc.md, config/arm/arm.c, config/arm/arm.md,
6834 config/c4x/c4x.c, config/c4x/c4x.md, config/cris/cris.md,
6835 config/frv/frv.c, config/h8300/h8300.c, config/ip2k/ip2k.md,
6836 config/iq2000/iq2000.c, config/m32r/m32r.c,
6837 config/mcore/mcore.c, config/mips/mips.c, config/mmix/mmix.md,
6838 config/mn10300/mn10300.c, config/rs6000/rs6000.c,
6839 config/rs6000/rs6000.md, config/sh/sh.c, config/sh/sh.md,
6840 config/stormy16/stormy16.c, config/v850/v850.md,
6841 config/xtensa/xtensa.c: Replace gen_rtx with gen_rtx_fmt_e*.
6843 2004-02-01 Kazu Hirata <kazu@cs.umass.edu>
6845 * config/mcore/mcore.c (block_move_sequence): Replace
6846 gen_rtx_CONST_INT with GEN_INT.
6848 2004-02-02 Jan Hubicka <jh@suse.cz>
6850 * alias.c (record_set): Use hard_regno_nregs.
6851 * bt-load.c (find_btr_reference, note_btr_set): Likewise.
6852 * builtins.c (apply_args_size): Likewise.
6853 * caller-save.c (setup_save_areas, save_call_clobbered_regs,
6854 mark_set_regs, add_stored_regs, mark_referenced_regs,
6855 insert_restore, insert_save, insert_one_insn): Likewise.
6856 * cfgcleanup.c: Include regs.h
6857 (mark_effect, mentions_nonequal_regs): Likewise.
6858 * cfgrtl.c (mark_killed_regs): Likewise
6859 * combine.c (update_table_tick, record_value_for_reg,
6860 record_dead_and_set_regs, get_last_value_validate, use_crosses_set_p,
6861 reg_dead_at_p_1, reg_dead_at_p, mark_used_regs_combine, move_deaths,
6862 reg_bitfield_target_p, distribute_notes): Likewise.
6863 * cse.c (mention_regs, insert, invalidate, invalidate_for_call,
6864 exp_equiv_p, cse_insn): Likewise.
6865 * cselib.c (cselib_lookup): Likewise.
6866 (cselib_invalidate_regno, cselib_record_set): Likewise.
6867 * df.c (df_ref_record): Likewise.
6868 * dwarf2out.c (reg_loc_descriptor, multiple_reg_loc_descriptor):
6870 * flow.c (mark_reg, insn_dead_p, mark_set_1, mark_used_reg,
6871 count_or_remove_death_notes_bb): Likewise.
6872 * function.c (aggregate_value_p, keep_stack_depressed): Likewise.
6873 * gloval.c (global_alloc, find_reg, mark_reg_store, mark_reg_conflicts,
6874 mark_reg_death, set_preference, reg_becomes_live, reg_dies): Likewise.
6875 * integrate.c (mark_stores): Likewise.
6876 * jump.c (delete_prior_computation): Likewise.
6877 * lcm.c (reg_dies, reg_becomes_live): Likewise.
6878 * local-alloc.c (combine_regs, find_free_reg, post_mark_life): Likewise.
6879 * loop.c (LOOP_REGNO_NREGS): Likewise.
6880 * postreload.c (reload_combine, reload_combine_note_store,
6881 reload_combine_note_use, reload_cse_move2add, move2add_note_store): Likewise.
6882 * ra-colorize.c (combine, color_usable_p, get_free_reg,
6883 calculate_dont_begin, calculate_dont_begin, colorize_one_web,
6884 try_recolor_web, insert_coalesced_conflicts, check_colors,
6885 break_precolored_alias): Likewise.
6886 * ra-debug.c: Include regs.h
6887 (ra_print_rtx_object): Likewise.
6888 * ra-rewrite (choose_spill_colors): Likewise.
6889 (spill_same_color_p, update_spill_colors, spill_is_free): Likewise.
6890 * ra.c (init_ra): Likewise.
6891 * recog.c (reg_fits_class_p, peep2_reg_dead_p,
6892 peep2_find_free_register): Likewise.
6893 * reg-stack.c (subst_stack_regs_pat, convert_regs_exit): Likewise.
6894 * regclass.c (hard_regno_nregs): New array.
6895 (init_reg_modes_once): Initialize it.
6896 (choose_hard_reg_mode): Use it.
6897 (record_reg_classes): Likewise.
6898 * regmove.c (mark_flags_life_zones): Likewise.
6899 * regrename.c (note_sets, clear_dead_regs, regrename_optimize,
6900 scan_rtx_reg, dump_def_use_chain, kill_value, set_value_regno,
6901 copy_value, maybe_mode_change, find_oldest_value_reg,
6902 copyprop_hardreg_forward_1):
6903 * regs.h (hard_regno_nregs): Declare.
6904 * realod.c (reload_inner_reg_of_subreg): Use it.
6905 (push_reload, combine_reloads, find_dummy_reload,
6906 hard_reg_set_here_p, operands_match_p, decompose, find_reloads,
6907 refers_to_regno_for_reload_p, find_equiv_reg, regno_clobbered_p,
6908 reload_adjust_reg_for_mode): Likewise.
6909 * reload1.c (compute_use_by_pseudos, count_pseudo,
6910 count_spilled_pseudo, find_reg, find_reload_regs, mark_home_live,
6911 spill_hard_reg, forget_old_reloads_1, mark_reload_reg_in_use,
6912 clear_reload_reg_in_use, reload_reg_free_for_value_p, free_for_value_p
6913 allocate_reload_reg, choose_reload_regs, emit_reload_insns,
6914 delete_output_reload): Likewise.
6915 * resource.c (update_live_status, mark_referenced_resources,
6916 mark_set_resources, mark_target_live_regs): Likewise.
6917 * rtlanal.c: Include regs.h
6918 (refers_to_regno_p, reg_overlap_mentioned_p, dead_or_set_p,
6919 dead_or_set_regno_p, find_regno_note, find_reg_fusage,
6920 subreg_regno_offset, subreg_offset_representable_p,
6921 hoist_test_store): Likewise.
6922 * sched-deps.c (sched_analyze_1, sched_analyze_2): Likewise.
6923 * sched-rgn.c (check_live_1, update_live_1): Likewise.
6924 * stmt.c: Include regs.h
6925 (decl_conflicts_with_clobbers_p): Likewise.
6926 * varasm.c (make_decl_rtl): Likewise.
6927 * Makefile.in (cfgcleanup.o, rtlanal.o, ra-debug.o): Add regs.h dependnecy.
6929 2004-02-01 Kazu Hirata <kazu@cs.umass.edu>
6931 * config/arm/arm.c, config/arm/arm.h, config/arm/arm.md,
6932 config/arm/linux-gas.h, config/arm/netbsd-elf.h,
6933 config/arm/netbsd.h, config/arm/pe.c, config/avr/avr.c,
6934 config/avr/avr.h, config/avr/avr.md, config/c4x/c4x.h,
6935 config/cris/cris.h, config/fr30/fr30.h, config/frv/frv.c,
6936 config/frv/frv.h, config/ip2k/ip2k.c, config/iq2000/iq2000.c,
6937 config/iq2000/iq2000.h, config/m32r/m32r.c,
6938 config/m68hc11/m68hc11.c, config/m68hc11/m68hc11.h,
6939 config/m68hc11/m68hc11.md, config/m68k/m68k.md,
6940 config/mcore/mcore.c, config/mcore/mcore.h,
6941 config/mcore/mcore.md, config/mips/mips.c,
6942 config/ns32k/ns32k.h, config/ns32k/ns32k.md,
6943 config/rs6000/rs6000.c, config/s390/s390.c,
6944 config/s390/s390.md, config/sparc/sparc.c, config/v850/v850.c,
6945 config/xtensa/xtensa.h, config/xtensa/xtensa.md: Replace
6946 "gen_rtx (FOO, " with "gen_rtx_FOO (".
6948 2004-02-01 Kazu Hirata <kazu@cs.umass.edu>
6950 * config/h8300/h8300.md (two peephole2's): New.
6952 2004-02-01 Eric Botcazou <ebotcazou@libertysurf.fr>
6954 * config/sparc/sol2-bi.h: Handle TARGET_CPU_ultrasparc3.
6955 (CPP_CPU_SPEC): Handle -mcpu=ultrasparc3.
6956 (ASM_CPU_SPEC): Likewise
6957 * config/sparc/sol2.h: Handle TARGET_CPU_ultrasparc3.
6958 (ASM_CPU_SPEC): Remove -mcpu=v8plus. Handle -mcpu=ultrasparc3.
6960 2004-02-01 Roger Sayle <roger@eyesopen.com>
6962 * builtins.c (expand_builtin_pow): If flag_unsafe_math_optimizations
6963 isn't set, don't call expand_builtin_mathfn_2 to use the pow optab.
6964 (expand_builtin): Always call expand_builtin_pow.
6966 2004-02-01 Roger Sayle <roger@eyesopen.com>
6968 * builtins.def (BUILT_IN_SIGNBIT, BUILT_IN_SIGNBITF,
6969 BUILT_IN_SIGNBITL): New GCC builtins.
6970 * builtins.c (expand_builtin_signbit): New function to RTL expand
6971 calls to signbit, signbitf and signbitl as inline intrinsics.
6972 (expand_builtin): Call expand_builtin_signbit for BUILT_IN_SIGNBIT*.
6973 (fold_builtin_signbit): New function to perform constant folding
6974 of signbit, signbitf and signbitl.
6975 (fold_builtin): Call fold_builtin_signbit for BUILT_IN_SIGNBIT*.
6977 * doc/extend.texi: Document new signbit{,f,l} builtins.
6979 2004-02-01 Richard Sandiford <rsandifo@redhat.com>
6981 * config/mips/mips.md (adddi3_internal_2): Remove superfluous %s.
6983 2004-02-01 Chris Demetriou <cgd@broadcom.com>
6985 * config/mips/mips.h (PREDICATE_CODES): Remove entries for
6986 "mips_const_double_ok" and "simple_memory_operand", which were
6987 removed from the MIPS port with the mips-3_4-rewrite branch merge.
6988 * config/mips/mips.c (mips16_lay_out_constants): Update comment
6989 for removal of simple_memory_operand.
6991 2004-01-31 Kazu Hirata <kazu@cs.umass.edu>
6993 * config/c4x/c4x.md: Use GEN_INT instead of
6994 gen_rtx (CONST_INT, ...).
6996 2004-01-31 Richard Henderson <rth@redhat.com>
6998 * varasm.c (output_constant_pool): Don't zap the pool.
7000 2004-01-31 Kazu Hirata <kazu@cs.umass.edu>
7002 * genrecog.c (decision_type): Add DT_const_int.
7003 (write_cond) [DT_const_int]: Print a comparison against small
7005 (write_node): Simplify comparisons against small constants
7006 before printing tests.
7008 2004-01-31 Kazu Hirata <kazu@cs.umass.edu>
7010 * config/m32r/m32r.c (m32r_load_pic_register): Use GEN_INT
7011 instead of gen_rtx_CONST_INT.
7013 2004-01-31 Kazu Hirata <kazu@cs.umass.edu>
7015 * config/xtensa/xtensa.h (DYNAMIC_CHAIN_ADDRESS): Use GEN_INT
7016 instead of gen_rtx_CONST_INT.
7018 2004-01-31 Kazu Hirata <kazu@cs.umass.edu>
7020 * target-def.h (TARGET_STRICT_ARGUMENT_NAMING): Define as
7021 hook_bool_CUMULATIVE_ARGS_false.
7022 * targhooks.c (default_strict_argument_naming): Rename to
7023 hook_bool_CUMULATIVE_ARGS_false.
7024 * targhooks.h: Update the prototype for
7025 default_strict_argument_naming.
7027 2004-01-31 Kazu Hirata <kazu@cs.umass.edu>
7029 * config/sh/sh.c: Replace "gen_rtx (FOO, " with "gen_rtx_FOO (".
7030 * config/sh/sh.h: Likewise.
7031 * config/sh/sh.md: Likewise.
7033 2004-01-31 Eric Botcazou <ebotcazou@libertysurf.fr>
7035 * doc/invoke.texi (SPARC options): Restructure and update.
7037 2004-01-31 Kazu Hirata <kazu@cs.umass.edu>
7039 * system.h (PROMOTE_FUNCTION_ARGS, STRUCT_VALUE_INCOMING, and
7040 STRICT_ARGUMENT_NAMING): Poison.
7041 * target-def.h (TARGET_PROMOTE_FUNCTION_ARGS): Define as
7042 hook_bool_tree_false.
7043 * targhooks.c (default_promote_function_args): Remove.
7044 (default_struct_value_rtx): Don't use STRUCT_VALUE_INCOMING.
7045 Don't check incoming.
7046 (default_strict_argument_naming): Don't use
7047 STRICT_ARGUMENT_NAMING.
7048 * targhooks.h: Remove the prototype for
7049 default_promote_function_args.
7051 2004-01-31 Kazu Hirata <kazu@cs.umass.edu>
7053 * config/i386/i386-protos.h: Remove the prototype for
7054 ix86_setup_incoming_varargs.
7055 * config/i386/i386.c (TARGET_SETUP_INCOMING_VARARGS): New.
7056 (ix86_setup_incoming_varargs): Make it static.
7057 * config/i386/i386.h (SETUP_INCOMING_VARARGS): Remove.
7059 2004-01-31 Kazu Hirata <kazu@cs.umass.edu>
7061 * alloc-pool.c: Fix comment typos.
7062 * builtin-types.def: Likewise.
7063 * builtins.def: Likewise.
7064 * c-pretty-print.c: Likewise.
7066 * reload1.c: Likewise.
7068 2004-01-31 Kazu Hirata <kazu@cs.umass.edu>
7070 * doc/invoke.texi: Follow spelling conventions.
7071 * doc/tm.texi: Likewise.
7073 2004-01-31 Kazu Hirata <kazu@cs.umass.edu>
7075 * doc/install.texi: Fix typos.
7076 * doc/invoke.texi: Likewise.
7078 2004-01-31 Ulrich Weigand <uweigand@de.ibm.com>
7080 * config/s390/s390.c (s390_decompose_address): Do not treat virtual
7081 registers as pointers.
7082 * config/s390/s390.md ("*la_31" second peephole2): Fix incorrect mode.
7084 2004-01-31 Paolo Bonzini <bonzini@gnu.org>
7086 * combine.c (cse_main): Set gen_lowpart to gen_lowpart_for_combine
7087 and restore it to gen_lowpart_general on exit.
7088 (gen_lowpart_for_combine): Adjust all callers to go through
7090 * cse.c (cse_main): Set gen_lowpart to gen_lowpart_if_possible
7091 and restore it to gen_lowpart_general on exit.
7092 (gen_lowpart_if_possible): Adjust all callers to go through
7094 * emit-rtl.c (gen_lowpart_general): New name of gen_lowpart.
7095 (gen_lowpart): Declare as pointer to function, initialized to
7096 gen_lowpart_general.
7097 * rtl.h (gen_lowpart): Declare as pointer to function.
7099 2004-01-31 Kazu Hirata <kazu@cs.umass.edu>
7101 * bt-load.c: Replace "gen_rtx (FOO, " with "gen_rtx_FOO (".
7102 * calls.c: Likewise.
7103 * emit-rtl.c: Likewise.
7104 * function.c: Likewise.
7105 * reload1.c: Likewise.
7106 * config/i386/cygming.h: Likewise.
7107 * config/i386/i386.c: Likewise.
7108 * config/i386/winnt.c: Likewise.
7110 2004-01-30 Dara Hazeghi <dhazeghi@yahoo.com>
7113 * doc/install.texi: document --enable-__cxa_atexit option.
7114 * configure.ac: Disable __cxa_atexit if not supported.
7115 * configure: Regenerate.
7117 2003-01-30 Daniel Berlin <dberlin@dberlin.org>
7119 * ggc-zone.c (ggc_free): New function.
7121 2004-01-30 Kazu Hirata <kazu@cs.umass.edu>
7123 alloc-pool.c, c-lex.c, c-pragma.h, c-semantics.c, cfghooks.c,
7124 cfghooks.h, cfglayout.c, cfgloopmanip.c, debug.c, debug.h,
7125 flow.c, genextract.c, ggc-common.c, ggc-page.c, ggc.h,
7126 ifcvt.c, jump.c, loop-unswitch.c, timevar.c, timevar.def,
7127 tree-optimize.c, vmsdbgout.c, config/fp-bit.c,
7128 config/alpha/alpha.c, config/alpha/alpha.h,
7129 config/alpha/alpha.md, config/alpha/unicosmk.h,
7130 config/alpha/vms.h, config/arm/linux-elf.h, config/avr/avr.c,
7131 config/c4x/c4x-protos.h, config/c4x/c4x.md,
7132 config/d30v/d30v.h, config/frv/frv.md, config/frv/frvbegin.c,
7133 config/frv/frvend.c, config/i386/cygming.h,
7134 config/i386/djgpp.h, config/i386/emmintrin.h,
7135 config/i386/gthr-win32.c, config/i386/i386-interix.h,
7136 config/i386/i386-protos.h, config/i386/openbsd.h,
7137 config/i386/winnt.c, config/i386/xm-mingw32.h,
7138 config/i386/xmmintrin.h, config/ia64/ia64.md,
7139 config/iq2000/iq2000.md, config/m32r/m32r.md,
7140 config/m68k/m68k.md, config/mcore/mcore-elf.h,
7141 config/mcore/mcore.md, config/mips/elf.h, config/mips/elf64.h,
7142 config/mips/iris5gas.h, config/mips/iris6.h,
7143 config/mips/iris6gas.h, config/mips/linux.h,
7144 config/mips/mips.md, config/mips/netbsd.h,
7145 config/mips/openbsd.h, config/mips/windiss.h,
7146 config/pa/fptr.c, config/rs6000/aix.h,
7147 config/rs6000/altivec.h, config/rs6000/darwin.h,
7148 config/rs6000/xcoff.h, config/s390/s390-protos.h,
7149 config/s390/s390.c, config/s390/s390.h, config/s390/s390.md,
7150 config/sh/netbsd-elf.h, config/sh/sh.h, config/sh/vxworks.h,
7151 config/sparc/sol2.h: Update copyright.
7153 2004-01-30 Kelley Cook <kcook@gcc.gnu.org>
7155 * Makefile.in (abs_docdir, abs_srcdir): Define.
7156 (doc/%.dvi, doc/gccinstall.dvi): Use $(abs_docdir).
7158 2004-01-30 Kazu Hirata <kazu@cs.umass.edu>
7160 * genconfig.c (main): Have CC0_P check its operand even on a
7163 2004-01-30 Kazu Hirata <kazu@cs.umass.edu>
7165 * config/alpha/alpha.c: Remove mentions of deprecates macros
7166 in comments, remove some target-independent comments about target
7167 macros, and/or add minimal function comments for target hook
7169 * config/avr/avr.c: Likewise.
7170 * config/ia64/ia64.h: Likewise.
7171 * config/ip2k/ip2k.c: Likewise.
7172 * config/iq2000/iq2000.c: Likewise.
7173 * config/m32r/m32r.h: Likewise.
7174 * config/m68hc11/m68hc11.c: Likewise.
7175 * config/mcore/mcore.c: Likewise.
7176 * config/mmix/mmix.c: Likewise.
7177 * config/mn10300/mn10300.c: Likewise.
7178 * config/pa/pa.c: Likewise.
7179 * config/pdp11/pdp11.c: Likewise.
7180 * config/rs6000/rs6000.h: Likewise.
7181 * config/sh/sh.c: Likewise.
7182 * config/sh/sh.h: Likewise.
7183 * config/sparc/sparc.c: Likewise.
7184 * config/sparc/sparc.h: Likewise.
7185 * config/stormy16/stormy16.c: Likewise.
7186 * config/xtensa/xtensa.c: Likewise.
7188 2004-01-30 Ulrich Weigand <uweigand@de.ibm.com>
7190 PR optimization/12147
7191 * reload1.c (reload_reg_free_p): RELOAD_OTHER conflicts with
7192 RELOAD_FOR_OPADDR_ADDR.
7193 (reload_reg_reaches_end_p): RELOAD_FOR_OTHER_ADDRESS register
7194 might be reused as RELOAD_FOR_OPADDR_ADDR register.
7196 2004-01-30 Jan Hubicka <jh@suse.cz>
7198 * reload.c (get_secondary_mem): Fix updating of
7199 secondary_memlocs_elim_used.
7201 2004-01-30 Richard Henderson <rth@redhat.com>
7203 * varasm.c (struct rtx_const, struct pool_constant): Remove.
7204 (MAX_RTX_HASH_TABLE): Remove.
7205 (const_rtx_hash_table, const_rtx_sym_hash_table): Remove.
7206 (first_pool, last_pool, pool_offset): Remove.
7207 (struct rtx_constant_pool): Split out from ...
7208 (struct varasm_status): ... here. Reference one via pointer.
7209 (struct constant_descriptor_rtx): Merge struct pool_constant.
7211 (decode_rtx_const): Remove.
7212 (const_hash_rtx, compare_constant_rtx): Remove.
7213 (record_constant_rtx): Remove.
7214 (const_desc_rtx_hash, const_desc_rtx_eq): New.
7215 (const_desc_rtx_sym_hash, const_desc_rtx_sym_eq): New.
7216 (const_rtx_hash_1, const_rtx_hash): New.
7217 (init_varasm_status): Allocate a rtx_constant_pool, and its hashes.
7218 (simplify_subtraction): Use simplify_rtx.
7219 (force_const_mem): Rewrite to use new data structures.
7220 (find_pool_constant): Likewise.
7221 (get_pool_constant, get_pool_constant_mark,
7222 get_pool_constant_for_function, get_pool_mode,
7223 get_pool_mode_for_function, get_pool_offset, get_pool_size): Likewise.
7224 (output_constant_pool_2): Split out from output_constant_pool.
7225 (output_constant_pool_1): Likewise. Use new pool datastructures.
7226 (output_constant_pool): Zap entire pool datastructure.
7227 (mark_constant): Use new pool datastructures.
7228 (mark_constants): Use for_each_rtx.
7229 (mark_constant_pool): Use new pool datastructures.
7231 2004-01-30 Fariborz Jahanian <fjahanian@apple.com>
7233 * config/rs6000/rs6000.c (rs6000_emit_move): Remove #if 0.
7234 Copy operands[1] to pseudo for simplify_gen_subreg.
7236 2004-01-30 Kazu Hirata <kazu@cs.umass.edu>
7238 * gcse.c (bypass_block): Fix a typo in the previous check-in
7241 2004-01-30 Andrew Pinski <pinskia@physics.uc.edu>
7243 * toplev.c: Include alloc-pool.h.
7244 * Makefile.in (toplev.c): Update dependencies.
7246 2004-01-30 Richard Kenner <kenner@vlsi1.ultra.nyu.edu>
7248 * combine.c (simplify_shift_const, case XOR): Be careful when
7249 commuting XOR with ASHIFTRT.
7251 2004-01-30 Kazu Hirata <kazu@cs.umass.edu>
7252 Eric Botcazou <ebotcazou@libertysurf.fr>
7254 * config/sparc/sparc-protos.h: Remove the prototype for
7255 sparc_builtin_saveregs.
7256 * config/sparc/sparc.c (TARGET_PROMOTE_FUNCTION_ARGS): New.
7257 (TARGET_PROMOTE_FUNCTION_RETURN): Likewise.
7258 (TARGET_PROMOTE_PROTOTYPES): Likewise.
7259 (TARGET_STRUCT_VALUE_RTX): Likewise.
7260 (TARGET_RETURN_IN_MEMORY): Likewise.
7261 (TARGET_EXPAND_BUILTIN_SAVEREGS): Likewise.
7262 (TARGET_STRICT_ARGUMENT_NAMING): Likewise.
7263 (sparc_builtin_saveregs): Make it static.
7264 (sparc_promote_prototypes): New.
7265 (sparc_struct_value_rtx): Likewise.
7266 (sparc_return_in_memory): Likewise.
7267 * config/sparc/sparc.h: (PROMOTE_FUNCTION_ARGS): Remove.
7268 (PROMOTE_FUNCTION_RETURN): Likewise.
7269 (RETURN_IN_MEMORY): Likewise.
7270 (STRUCT_VALUE): Likewise.
7271 (STRUCT_VALUE_INCOMING): Likewise.
7272 (EXPAND_BUILTIN_SAVEREGS): Likewise.
7273 (STRICT_ARGUMENT_NAMING): Likewise.
7274 (PROMOTE_PROTOTYPES): Likewise.
7276 * config/sparc/sparc.h (PROMOTE_MODE): Use word_mode.
7278 2004-01-30 Eric Botcazou <ebotcazou@libertysurf.fr>
7281 * varasm.c (const_hash_1) <STRING_CST>: Use the
7282 address to compute the hash value if flag_writable_strings.
7283 (compare_constant) <STRING_CST>: Compare the addresses
7284 if flag_writable_strings.
7285 (build_constant_desc): Do not copy the expression for a
7286 STRING_CST if flag_writable_strings.
7288 2004-01-30 Jan Hubicka <jh@suse.cz>
7290 * alloc-pool.c: Include hashtab.h
7291 (alloc_pool_descriptor): New structure
7292 (alloc_pool_hash): New global variable.
7293 (hash_descriptor, eq_descriptor, alloc_pool_descriptor): New.
7294 (create_alloc_pool): Update statistics.
7295 (free_alloc_pool): Likewise.
7296 (pool_alloc): Likewise.
7297 (output_info): New structure
7298 (print_statistics, dump_alloc_pool_statistics): New function.
7299 * alloc-pool.h (alloc_pool_def): Turn name to be constant.
7300 (dump_alloc_pool_statistics): Declare.
7301 * toplev.c (finalize): Dump statistics.
7303 * reload.c (secondary_memlocs_elim_used): New static variable.
7304 (get_secondary_mem): Update it.
7305 (find_reloads): Use it.
7307 2004-01-30 Steven Bosscher <s.bosscher@student.tudelft.nl>
7309 * toplev.c: Fix broken checkin of 2003-12-30, again.
7311 2004-01-30 Ulrich Weigand <uweigand@de.ibm.com>
7313 * configure.ac (gcc_cv_as_dwarf2_debug_line): Enable test for
7314 s390*-*-* targets by specifying a 'nop' insn.
7315 * configure: Regenerate.
7317 2004-01-30 Eric Botcazou <ebotcazou@libertysurf.fr>
7320 * config/sparc/sparc.md (movhi_lo_sum): Tighten predicates.
7322 2004-01-29 Jakub Jelinek <jakub@redhat.com>
7324 * emit-rtl.c (change_address): Use XEXP (memref, 0) instead
7325 of addr when creating MEM copy.
7327 2004-01-29 Devang Patel <dpatel@apple.com>
7329 * dwarf2out.c (gen_field_die): Do not equate decl number to die.
7331 2004-01-28 Ian Lance Taylor <ian@wasabisystems.com>
7334 * reload.c (find_reloads): Only support one pair of commutative
7337 2004-01-29 Roger Sayle <roger@eyesopen.com>
7340 * tree.c (unsafe_for_reeval): Handle EXIT_BLOCK_EXPR nodes specially
7341 as their EXIT_BLOCK_LABELED_BLOCK operands can lead to unbounded
7344 2004-01-29 Kazu Hirata <kazu@cs.umass.edu>
7346 * config/frv/frv.c: Don't mention deprecated macros in
7347 comments. Remove some target-independent comments about
7349 * config/frv/frv.h: Likewise.
7351 2004-01-29 Zdenek Dvorak <rakdver@atrey.karlin.mff.cuni.cz>
7353 * cfghooks.c (split_block): Set probability and count of the
7356 2005-01-29 Josef Zlomek <zlomekj@suse.cz>
7358 * dwarf2out.c (struct die_struct): Added field decl_id.
7359 (decl_die_table): Changed to hash table.
7360 (decl_die_table_allocated): Deleted.
7361 (decl_die_table_in_use): Deleted.
7362 (DECL_DIE_TABLE_INCREMENT): Deleted.
7363 (decl_die_table_hash): New function.
7364 (decl_die_table_eq): New function.
7365 (lookup_decl_die): Lookup in a hash table.
7366 (equate_decl_number_to_die): Insert into a hash table.
7367 (dwarf2out_init): Init hash table decl_die_table.
7369 2004-01-29 Jakub Jelinek <jakub@redhat.com>
7371 PR optimization/13424
7372 * expr.c (store_constructor): Revert 2003-12-03 change.
7374 * emit-rtl.c (change_address): Check also if MEM_ATTRS is set as
7375 expected before returning early. Avoid sharing RTL if they
7378 * config/i386/i386.c (ix86_expand_movstr): Rework rep_mov and strmov
7379 handling so that memory attributes are preserved. Don't call
7380 ix86_set_move_mem_attrs.
7381 (ix86_set_move_mem_attrs_1, ix86_set_move_mem_attrs): Removed.
7382 (ix86_expand_clrstr): Rename src argument to
7383 dst. Rework rep_stos and strset handling so that memory attributes
7385 (ix86_expand_strlen): Pass src argument to
7386 ix86_expand_strlensi_unroll_1. Rework strlenqi_1 handling so that
7387 memory attributes are preserved.
7388 (ix86_expand_strlensi_unroll_1): Add src argument. Use
7389 change_address instead of gen_rtx_MEM.
7390 * config/i386/i386.md (strmov, strmov_singleop, rep_mov): New
7392 (strmovdi_rex64, strmovsi, strmovsi_rex64, strmovhi, strmovhi_rex64,
7393 strmovqi, strmovqi_rex64): Remove.
7394 (rep_mov*, strmov*): Prefix insn names with *.
7395 (strset, strset_singleop, rep_stos): New expanders.
7396 (strsetdi_rex64, strsetsi, strsetsi_rex64, strsethi, strsethi_rex64,
7397 strsetqi, strsetqi_rex64): Remove.
7398 (rep_stos*, strset*): Prefix insn names with *.
7399 (rep_stosqi_rex64): Likewise. Fix mode of dirflag reg from DImode
7401 (cmpstrsi): Rework cmpstrqi_1 handling so that memory attributes
7403 (cmpstrqi_nz_1, cmpstrqi_nz_rex_1, cmpstrqi_1, cmpstrqi_rex_1):
7404 Prefix insn names with *.
7405 (cmpstrqi_nz_1, cmpstrqi_1): New expanders.
7406 (strlenqi_1, strlenqi_rex_1): Prefix insn names with *.
7407 (strlenqi_1): New expander.
7408 * config/i386/i386.h (ix86_set_move_mem_attrs): Remove prototype.
7410 2004-01-29 Zdenek Dvorak <rakdver@atrey.karlin.mff.cuni.cz>
7412 * Makefile.in (cfghooks.o): Add TIMEVAR_H and toplev.h dependency.
7413 * basic-block.h (tidy_fallthru_edge, tidy_fallthru_edges, dump_bb,
7414 verify_flow_info): Declaration removed.
7415 * cfg.c (verify_flow_info, dump_bb): Moved to cfghooks.c.
7416 (debug_bb, debug_bb_n): Add argument to dump_bb call.
7417 * cfgcleanup.c (try_simplify_condjump, try_crossjump_to_edge,
7418 try_optimize_cfg, delete_unreachable_blocks): Use delete_basic_block
7419 instead of delete_block.
7420 * cfghooks.c: Include timevar.h and toplev.h.
7421 (cfg_hooks): Define here.
7422 (verify_flow_info, dump_bb): Moved from cfg.c.
7423 (redirect_edge_and_branch, redirect_edge_and_branch_force,
7424 split_block, split_block_after_labels, move_block_after,
7425 delete_basic_block, split_edge, create_basic_block,
7426 create_empty_bb, can_merge_blocks_p, merge_blocks,
7427 make_forwarder_block, tidy_fallthru_edge, tidy_fallthru_edges):
7429 * cfghooks.h (struct cfg_hooks): Added fields name,
7430 make_forwarder_block, tidy_fallthru_edge and
7431 move_block_after. Changed type of verify_flow_info, dump_bb,
7432 split_block fields. Renamed cfgh_split_edge and delete_block
7434 (redirect_edge_and_branch, redirect_edge_and_branch_force,
7435 split_block, delete_block, split_edge, create_basic_block,
7436 can_merge_blocks_p, merge_blocks): Macros removed.
7437 (cfg_hooks): Do not export.
7438 (verify_flow_info, dump_bb, redirect_edge_and_branch,
7439 redirect_edge_and_branch_force, split_block, split_block_after_labels,
7440 move_block_after, delete_basic_block, split_edge, create_basic_block,
7441 create_empty_bb, can_merge_blocks_p, merge_blocks,
7442 make_forwarder_block, tidy_fallthru_edge, tidy_fallthru_edges):
7444 (cfg_layout_rtl_cfg_hooks): Declare.
7445 * cfgloop.c (update_latch_info, mfb_keep_just, mfb_keep_nonlatch):
7447 (canonicalize_loop_headers): Use new semantics of make_forwarder_block.
7448 (redirect_edge_with_latch_update): Removed.
7449 (make_forwarder_block): Moved to cfghooks.c, semantics changed.
7450 * cfgloopmanip.c (remove_bbs): Do not update dominators here.
7451 * cfgrtl.c (cfg_layout_split_block, rtl_split_block, rtl_dump_bb,
7452 rtl_delete_block, rtl_split_block, rtl_merge_blocks,
7453 tidy_fallthru_edge, rtl_split_edge, cfg_layout_delete_block,
7454 cfg_layout_merge_blocks, cfg_layout_split_edge): Partly moved to
7456 (rtl_create_basic_block): Coding style fix.
7457 (rtl_tidy_fallthru_edge, rtl_move_block_after,
7458 rtl_make_forwarder_block): New functions.
7459 (update_cfg_after_block_merging): Removed.
7460 (rtl_cfg_hooks, cfg_layout_rtl_cfg_hooks): Fill in new entries.
7461 * flow.c (verify_wide_reg, verify_local_live_at_start): Add argument
7463 * ifcvt.c (merge_if_block, find_cond_trap, find_if_case_1,
7464 find_if_case_2): Don't update dominators.
7465 * timevar.def (TV_CFG_VERIFY): New.
7466 * loop-unswitch.c (unswitch_loop): Don't call add_to_dominance_info.
7467 * cfglayout.c (copy_bbs): Don't call add_to_dominance_info.
7468 * cfgloopmanip.c (split_loop_bb): Don't update dominators.
7469 (remove_bbs): Don't call remove_bbs.
7470 (create_preheader): Use make_forwarder_block.
7471 (mfb_keep_just, mfb_update_loops): New static functions.
7473 2004-01-29 Kazu Hirata <kazu@cs.umass.edu>
7475 * config/avr/avr.h: Remove target-independent comments about
7478 2004-01-28 Daniel Berlin <dberlin@dberlin.org>
7480 * timevar.c (timevar_print): Mention when checking is enabled.
7482 2004-01-28 Giovanni Bajo <giovannibajo@gcc.gnu.org>
7484 * c-lex.c (c_lex): Rename to...
7485 (c_lex_with_flags): Add new parameter to get CPP flags.
7486 (c_lex): Thunk to c_lex_with_flags while keeping the old interface.
7487 * c-pragma.h (c_lex_with_flags): Declare.
7489 2004-01-28 Kazu Hirata <kazu@cs.umass.edu>
7491 * config/mcore/mcore.c (mcore_external_libcall): Add a
7493 (mcore_return_in_memory): Likewise.
7495 2004-01-28 Kazu Hirata <kazu@cs.umass.edu>
7497 * config/mcore/mcore-protos.h: Remove the prototype for
7498 mcore_setup_incoming_varargs.
7499 * config/mcore/mcore.c (TARGET_ASM_EXTERNAL_LIBCALL): New.
7500 (TARGET_PROMOTE_FUNCTION_ARGS): Likewise.
7501 (TARGET_PROMOTE_FUNCTION_RETURN): Likewise.
7502 (TARGET_PROMOTE_PROTOTYPES): Likewise.
7503 (TARGET_STRUCT_VALUE_RTX): Likewise.
7504 (TARGET_RETURN_IN_MEMORY): Likewise.
7505 (TARGET_SETUP_INCOMING_VARARGS): Likewise.
7506 (mcore_setup_incoming_varargs): Make it static. Receive the
7507 first argument by reference. Add argument second_time.
7508 (mcore_external_libcall): New.
7509 (mcore_return_in_memory): Likewise.
7510 * config/mcore/mcore.h (PROMOTE_FUNCTION_ARGS): New.
7511 (PROMOTE_FUNCTION_RETURN): Likewise.
7512 (STRUCT_VALUE): Likewise.
7513 (RETURN_IN_MEMORY): Likewise.
7514 (SETUP_INCOMING_VARARGS): Likewise.
7515 (PROMOTE_PROTOTYPES): Likewise.
7516 (ASM_OUTPUT_EXTERNAL_LIBCALL): Likewise.
7518 2004-01-28 Kazu Hirata <kazu@cs.umass.edu>
7520 * config/m32r/m32r-protos.h: Remove the prototype for
7521 m32r_setup_incoming_varargs.
7522 * config/m32r/m32r.c (TARGET_PROMOTE_PROTOTYPES): New.
7523 (TARGET_STRUCT_VALUE_RTX): Likewise.
7524 (TARGET_RETURN_IN_MEMORY): Likewise.
7525 (TARGET_SETUP_INCOMING_VARARGS): Likewise.
7526 (m32r_return_in_memory): New.
7527 (m32r_setup_incoming_varargs): Make it static.
7528 * config/m32r/m32r.h: Remove #undef of
7529 ASM_OUTPUT_EXTERNAL_LIBCALL. Remove the commented-out
7530 definitions of PROMOTE_FUNCTION_ARGS and
7531 PROMOTE_FUNCTION_RETURN.
7532 (PROMOTE_PROTOTYPES): Remove.
7533 (RETURN_IN_MEMORY): Likewise.
7534 (STRUCT_VALUE): Likewise.
7536 2004-01-28 Kazu Hirata <kazu@cs.umass.edu>
7538 * config/m68k/m68k.c (TARGET_PROMOTE_PROTOTYPES): New.
7539 (TARGET_STRUCT_VALUE_RTX): Likewise.
7540 (m68k_struct_value_rtx): Likewise.
7541 * config/m68k/m68k.h (STRUCT_VALUE_REGNUM): Rename to
7542 STRUCT_VALUE_REGNUM.
7543 (PROMOTE_PROTOTYPES): Remove.
7544 * config/m68k/m68kelf.h (STRUCT_VALUE_REGNUM): Rename to
7545 STRUCT_VALUE_REGNUM.
7546 * config/m68k/m68kv4.h (STRUCT_VALUE_REGNUM): Likewise.
7547 * config/m68k/netbsd-elf.h (STRUCT_VALUE_REGNUM): Likewise.
7549 2004-01-28 Kazu Hirata <kazu@cs.umass.edu>
7551 * config/stormy16/stormy16.c
7552 (TARGET_BUILD_BUILTIN_VA_LIST_TYPE): Rename to
7553 TARGET_BUILD_BUILTIN_VA_LIST.
7555 2004-01-28 Kazu Hirata <kazu@cs.umass.edu>
7557 * config/v850/v850.c (TARGET_PROMOTE_PROTOTYPES): New.
7558 (TARGET_STRUCT_VALUE_RTX): Likewise.
7559 (TARGET_RETURN_IN_MEMORY): Likewise.
7560 (TARGET_SETUP_INCOMING_VARARGS): Likewise.
7561 (v850_return_in_memory): Likewise.
7562 (v850_setup_incoming_varargs): Likewise.
7563 * config/v850/v850.h (PROMOTE_PROTOTYPES): Remove.
7564 (SETUP_INCOMING_VARARGS): Likewise.
7565 (RETURN_IN_MEMORY): Likewise.
7566 (STRUCT_VALUE): Likewise.
7568 2004-01-28 Kazu Hirata <kazu@cs.umass.edu>
7570 * config/fr30/fr30.c (TARGET_PROMOTE_PROTOTYPES): New.
7571 (fr30_setup_incoming_varargs): Don't use
7572 STRICT_ARGUMENT_NAMING.
7573 * config/fr30/fr30.h (PROMOTE_PROTOTYPES): Remove.
7574 (STRICT_ARGUMENT_NAMING): Likewise.
7576 2004-01-28 Kazu Hirata <kazu@cs.umass.edu>
7578 * config/frv/frv-protos.h: Remove the prototype for
7579 frv_expand_builtin_saveregs.
7580 * config/frv/frv.c (TARGET_STRUCT_VALUE_RTX): Likewise.
7581 (TARGET_EXPAND_BUILTIN_SAVEREGS): Likewise.
7582 (frv_stack_info): Use FRV_STRUCT_VALUE_REGNUM instead of
7583 STRUCT_VALUE_REGNUM.
7584 (frv_expand_builtin_saveregs): Make it static.
7585 (frv_struct_value_rtx): New.
7586 * config/frv/frv.h (EXPAND_BUILTIN_SAVEREGS): Remove.
7588 2004-01-29 Jan Hubicka <jh@suse.cz>
7591 * cgraph.c (cgraph_remove_node): Clear out saved/insns/arguments and
7593 * cgraphunit.c (cgraph_finalize_function): Clear out DECL_SAVED_INSNS
7594 for functions that will be only inlined.
7595 (cgraph_mark_function_to_output): Likewise.
7596 (cgraph_expand_function): Sanity check that DECL_DEFER_OUTPUT is clear;
7597 do not clear function body.
7598 * tree-optimize.c (clear_decl_rtl): Use decl_function_context.
7599 (tree_rest_of_compilation): Reorganize the logic releasing function
7600 body to use callgraph datastructure.
7602 2004-01-28 John David Anglin <dave.anglin@nrc-cnrc.gc.ca>
7604 * pa.md: Change predicate of a peephole2 pattern from reg_or_0_operand
7605 to register_operand.
7607 2004-01-28 Zack Weinberg <zack@codesourcery.com>
7609 * config/ia64/ia64.md (fetchadd_acq_si, fetchadd_acq_di)
7610 (cmpxchg_acq_si, cmpxchg_acq_di): Exchange match_dup and
7611 match_operand expressions so that all match_dups appear
7612 lexically after their corresponding match_operands.
7614 2004-01-28 Kazu Hirata <kazu@cs.umass.edu>
7616 * config/h8300/h8300.c (WORD_REG_USED): Use
7617 HARD_FRAME_POINTER_REGNUM instead of FRAME_POINTER_REGNUM.
7618 (compute_saved_regs): Likewise.
7619 (h8300_expand_prologue): Likewise. Allocate locals after
7621 (h8300_expand_epilogue): Use HARD_FRAME_POINTER_REGNUM instead
7622 of FRAME_POINTER_REGNUM. Deallocate locals before saving
7624 (h8300_initial_elimination_offset): Adjust for the new frame
7625 layout, which swaps flips the order of locals and saved
7627 * config/h8300/h8300.h (FIRST_PSEUDO_REGISTER): Change to 12.
7628 (HARD_FRAME_POINTER_REGNUM): New.
7629 (ELIMINABLE_REGS): Add an elimination rule from
7630 FRAME_POINTER_REGNUM to HARD_FRAME_POINTER_REGNUM.
7631 (REGISTER_NAMES): Add fp.
7632 * config/h8300/h8300.md (FP_REG): Change to 11.
7635 2004-01-28 Kazu Hirata <kazu@cs.umass.edu>
7637 * genrecog.c (write_node): Remove a useless local variable.
7639 2004-01-28 Ian Lance Taylor <ian@wasabisystems.com>
7641 * Makefile.in (options.c options.h): Use stamp file s-options to
7642 avoid unnecessary rebuilds.
7643 (options.o): New target listing dependencies.
7644 (gtyp-gen.h): Use stamp file s-gtyp-gen.
7645 (STAGESTUFF): Add s-gtyp-gen.
7647 2004-01-28 Richard Henderson <rth@redhat.com>
7649 * ggc.h (ggc_free): Declare.
7650 * ggc-common.c (ggc_realloc): Use it.
7651 * ggc-page.c: Remove lots of inline markers.
7652 (globals): Add free_object_list.
7654 (ggc_free, validate_free_objects): New.
7655 (poison_pages): Provide default.
7656 (ggc_collect): Call validate_free_objects; emit markers to
7659 2004-01-28 Zack Weinberg <zack@codesourcery.com>
7660 Jim Wilson <wilson@specifixinc.com>
7662 * config/ia64/ia64.c (ia64_split_tmode, ia64_split_tmode_move):
7663 Rewrite to use POST_INC/POST_DEC/POST_MODIFY instead of a
7665 (ia64_secondary_reload_class): Delete case GR_REGS.
7666 * config/ia64/ia64.md (movti, *movti_internal, movtf, *movtf_internal):
7667 Do not allocate a scratch register.
7668 (reload_inti, reload_outti, reload_intf, reload_outtf): Delete.
7670 2004-01-28 Jan Hubicka <jh@suse.cz>
7672 * gcse.c (bypass_block): Prevent edges to be unified when we are
7673 about to emit compenstation code.
7675 2004-01-28 Nick Clifton <nickc@redhat.com>
7677 * config/arm/arm.c (arm_expand_builtin): Force second argument of
7678 the setcwx insn into a register.
7680 2004-01-28 Richard Sandiford <rsandifo@redhat.com>
7682 * config/fp-bit.c (pack_d): When using paired doubles to implement
7683 a long double, round the high part separately.
7684 (unpack_d): Fix the case in which the high part is a power of two
7685 and the low part is a nonzero value of the opposite sign.
7687 2004-01-28 Kazu Hirata <kazu@cs.umass.edu>
7689 * config/c4x/c4x.c (TARGET_ASM_EXTERNAL_LIBCALL): New.
7690 (TARGET_STRUCT_VALUE_RTX): Likewise.
7691 (c4x_external_libcall): Likewise.
7692 (c4x_struct_value_rtx): Likewise.
7693 * config/c4x/c4x.h: Remove.
7694 (STRUCT_VALUE_REGNUM): Likewise.
7695 (ASM_OUTPUT_EXTERNAL_LIBCALL): Likewise.
7697 2004-01-28 Kazu Hirata <kazu@cs.umass.edu>
7699 * config/i386/i386.c (TARGET_PROMOTE_PROTOTYPES): New.
7700 (TARGET_STRUCT_VALUE_RTX): Likewise.
7701 * config/i386/i386.h (STRUCT_VALUE_INCOMING): Remove.
7702 (STRUCT_VALUE): Likewise.
7703 (PROMOTE_PROTOTYPES): Likewise.
7705 2004-01-27 Roger Sayle <roger@eyesopen.com>
7707 * config/pa/pa.c (emit_move_sequence): Check that operand1 is a
7708 CONST_INT before using INTVAL.
7710 2004-01-27 Ulrich Weigand <uweigand@de.ibm.com>
7712 * config/s390/s390.h (TARGET_DEFAULT): Default to !TARGET_BACKCHAIN.
7713 * config/s390/s390.c (s390_return_addr_rtx): Fail for all but current
7714 frame if !TARGET_BACKCHAIN.
7715 * config/s390/s390.md ("allocate_stack"): Use pattern only if
7717 * doc/invoke.texi (-mbackchain/-mno-backchain): Document new default.
7719 2004-01-27 Zack Weinberg <zack@codesourcery.com>
7721 * ia64.c (ia64_function_arg): When placing HFAs in integer
7722 registers, do not special case the mode used for complex
7723 types. Do not advance int_regs until the current register
7726 2004-01-27 Richard Sandiford <rsandifo@redhat.com>
7729 * except.c (init_eh): Use a 5-word __jbuf for __builtin_setjmp().
7731 2004-01-27 David Edelsohn <edelsohn@gnu.org>
7733 * config/rs6000/rs6000.c (rs6000_emit_move): #if 0 splitting
7734 slow, unaligned loads and stores while debugging. Fix formatting.
7736 2004-01-27 David Edelsohn <edelsohn@gnu.org>
7738 * config/rs6000/rs6000.md (save_stack_nonlocal): Use Pmode instead
7740 (restore_stack_nonlocal): Same.
7742 2004-01-27 Devang Patel <dpatel@apple.com>
7744 * Makefile.in (dwarf2out.o): Depend on input.h
7745 * dbxout.c (dbx_debug_hooks): Add new empty hook for
7746 imported_module_or_decl.
7747 (xcoff_debug_hooks): Same.
7748 * sdbout.c (sdb_debug_hooks): Same.
7749 * vmsdbgout.c (vmsdbg_debug_hooks): Same.
7750 * debug.c (do_nothing_debug_hooks): Same.
7751 (debug_nothing_tree_tree): New function.
7752 * debug.h (gcc_debug_hooks): New hook, imported_module_or_decl.
7753 * dwarf2out.c: Include input.h.
7754 (dwarf2_debug_hooks): Add new hook for imported_module_or_decl.
7755 (remove_child_TAG): New function.
7756 (dwarf_tag_name): Handle DW_TAG_imported_module.
7757 (gen_subprogram_die): Equate decl number to declaration die. Do not
7758 remove all children dies while reusing declaration die for definition.
7759 Instead, selectively remove only formal parameters.
7760 (gen_variable_die): Equate variable decl to declaration die.
7761 (gen_field_die): Equate field decl to line number.
7762 (force_namespace_die): Replace it with ...
7763 (force_decl_die): ... this.
7764 (force_type_die): New function.
7765 (setup_namespace_context): Replace use of force_namespace_die() with
7767 (gen_namespace_die): Same.
7768 (dwarf2out_imported_module_or_decl): New function.
7770 2004-01-27 Bob Wilson <bob.wilson@acm.org>
7772 * config/xtensa/xtensa.c (xtensa_copy_incoming_a7): Remove SUBREG
7773 on CQImode and CHImode incoming arguments in register a7.
7774 (function_arg): Wrap BLKmode argument in register a7 in a PARALLEL.
7775 * config/xtensa/xtensa.h (BLOCK_REG_PADDING): Define.
7776 * config/xtensa/xtensa.md (movdi, movdf): Only call force_reg or
7777 xtensa_copy_incoming_a7 before reload.
7779 2004-01-27 J"orn Rennecke <joern.rennecke@superh.com>
7781 * coverage.c (get_coverage_counts): Give a different message
7782 if flag_guess_branch_prob is set.
7783 * predict.c (counts_to_freqs): Return an int.
7784 (estimate_bb_frequencies): If counts_to_freqs returns zero,
7785 calculate estimates.
7787 2004-01-27 Kazu Hirata <kazu@cs.umass.edu>
7789 * config/iq2000/iq2000-protos.h: Remove the prototype for
7790 iq2000_setup_incoming_varargs.
7791 * config/iq2000/iq2000.c (TARGET_PROMOTE_FUNCTION_ARGS): New.
7792 (TARGET_PROMOTE_FUNCTION_RETURN): Likewise.
7793 (TARGET_PROMOTE_PROTOTYPES): Likewise.
7794 (TARGET_STRUCT_VALUE_RTX): Likewise.
7795 (TARGET_RETURN_IN_MEMORY): Likewise.
7796 (TARGET_SETUP_INCOMING_VARARGS): Likewise.
7797 (TARGET_STRICT_ARGUMENT_NAMING): Likewise.
7798 (iq2000_return_in_memory): Likewise.
7799 (iq2000_setup_incoming_varargs): Make it static. Receive the
7800 first argument by reference.
7801 * config/iq2000/iq2000.h (PROMOTE_FUNCTION_ARGS): Remove.
7802 (PROMOTE_FUNCTION_RETURN): Likewise.
7803 (PROMOTE_PROTOTYPES): Likewise.
7804 (RETURN_IN_MEMORY): Likewise.
7805 (STRUCT_VALUE): Likewise.
7806 (SETUP_INCOMING_VARARGS): Likewise.
7807 (STRICT_ARGUMENT_NAMING): Likewise.
7809 2004-01-24 James A. Morrison <ja2morri@uwaterloo.ca>
7811 * fixinc/fixinc.c (test_test): Initialize res.
7812 (start_flexer): Initialize pz_cmd_save.
7814 2004-01-27 Zack Weinberg <zack@codesourcery.com>
7816 * doc/rtl.texi (Arithmetic): Rewrite entries for PLUS,
7817 SS_PLUS, US_PLUS, LO_SUM, MINUS, SS_MINUS, US_MINUS.
7819 2004-01-27 Zack Weinberg <zack@codesourcery.com>
7822 * config/ia64/ia64.md (*nmaddsf4, *nmadddf4, *nmadddf4_alts)
7823 (*nmadddf4_trunc, *nmaddxf4, *nmaddxf4_truncsf, *nmaddxf4_truncdf)
7824 (*nmaddxf4_alts, *nmaddxf4_truncdf_alts):
7825 Rewrite pattern as (minus (op 3) (mult (op 1) (op 2))).
7826 Possibly rename pattern for consistency.
7827 Remove ??? comments suggesting that this be done.
7828 (*nmaddsf4_alts, *nmadddf4_truncsf_alts, *nmaddxf4_truncsf_alts):
7830 (divsi3_internal, divdi3_internal_lat, divdi3_internal_thr)
7831 (divsf3_internal_lat, divsf3_internal_thr, sqrtsf2_internal_thr)
7832 (divdf3_internal_lat, divdf3_internal_thr, sqrtdf2_internal_thr)
7833 (divxf3_internal_lat, divxf3_internal_thr, sqrtxf2_internal_thr):
7836 2004-01-27 Ian Lance Taylor <ian@wasabisystems.com>
7838 * config/arm/arm.c (output_return_instruction): Only restore IP
7839 into SP if frame_pointer_needed.
7841 2004-01-27 Eric Botcazou <ebotcazou@libertysurf.fr>
7843 * config/sparc/sparc.c (function_arg_pass_by_reference): Return 1
7844 for SCmode and DCmode if ARCH32.
7845 (sparc_va_arg): Handle SCmode and DCmode by reference if ARCH32.
7846 * config/sparc/sparc.h (RETURN_IN_MEMORY): Return 0 for TCmode
7848 (BASE_RETURN_VALUE_REG): Return 32 for all FP modes except TFmode
7850 (BASE_OUTGOING_VALUE_REG): Likewise.
7852 2004-01-27 Eric Botcazou <ebotcazou@libertysurf.fr>
7856 * config/sparc/sparc.h (CANNOT_CHANGE_MODE_CLASS): New.
7857 Forbid mode changes from SImode for lower FP regs if ARCH64.
7859 2004-01-27 J"orn Rennecke <joern.rennecke@superh.com>
7861 * Makefile.in (bt-load.o): Depend on except.h.
7862 * bt-load.c (except.h): #include.
7863 (compute_defs_uses_and_gen): If insn at end of BB can throw
7864 within this function, consider registers used by it unavailable for
7866 (move_btr_def): If insn at end of BB can throw, insert before rather
7869 * flags.h (flag_btr_bb_exclusive): Declare.
7870 * toplev.c (flag_btr_bb_exclusive): New variable.
7871 (f_options): Add btr-bb-exclusive.
7872 * bt-load.c (augment_live_range): Restore old behaviour if
7873 flag_btr_bb_exclusive is set.
7874 * common.opt: Add entry for -fbtr-bb-exclusive.
7875 * opts.c (common_handle_options): Same.
7876 * doc/invoke.texi: Document -fbtr-bb-exclusive.
7878 * bt-load.c (btrs_live_at_end): New variable.
7879 (compute_defs_uses_and_gen): Compute its pointed-to array.
7880 (clear_btr_from_live_range, add_btr_to_live_range): Update it.
7881 (augment_live_range): When augmenting with a new dominator,
7882 use only its btrs_live_at_end set, but also add in the full set
7883 of the old dominator.
7884 (btr_def_live_range): Use btrs_live_at_end.
7885 (move_btr_def): Set other_btr_uses_before_def, and move new set
7886 to the end of the basic block, if appropriate.
7887 (migrate_btr_defs): Allocate and free btrs_live_at_end.
7889 * bt-load.c (basic_block_freq): Remove outdated comment.
7891 2004-01-27 Alan Modra <amodra@bigpond.net.au>
7893 * config/rs6000/rs6000.h: Correct target_flags free bits comment.
7894 (PREDICATE_CODES): Remove duplicate.
7895 * config/rs6000/linux64.h (CPP_SYSV_SPEC): Don't define.
7896 (SUBSUBTARGET_OVERRIDE_OPTIONS): Disallow 32 bit TARGET_PROFILE_KERNEL.
7897 (MASK_PROFILE_KERNEL): Adjust define.
7899 2004-01-27 Jakub Jelinek <jakub@redhat.com>
7901 * config/i386/i386.c (ix86_constant_alignment): Decrease alignment
7902 of long string literals from 32 bytes to sizeof (void *) when !-Os
7905 2004-01-26 Kazu Hirata <kazu@cs.umass.edu>
7907 * config/h8300/h8300.c (h8300_tiny_constant_address_p): Accept
7908 constant addresses in the normal mode.
7910 2004-01-26 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
7912 * system.h (CHAR_BITFIELD): Delete.
7913 (BOOL_BITFIELD): New.
7914 * c-decl.c (c_scope): Use BOOL_BITFIELD.
7915 * gengtype-lex.l: Recognize BOOL_BITFIELD instead of CHAR_BITFIELD.
7917 2004-01-26 Kazu Hirata <kazu@cs.umass.edu>
7919 * config/arc/arc.c (TARGET_PROMOTE_FUNCTION_ARGS): New.
7920 (TARGET_PROMOTE_FUNCTION_RETURN): Likewise.
7921 (TARGET_PROMOTE_PROTOTYPES): Likewise.
7922 (TARGET_STRUCT_VALUE_RTX): Likewise.
7923 (TARGET_RETURN_IN_MEMORY): Likewise.
7924 (arc_return_in_memory): Likewise.
7925 * config/arc/arc.h (PROMOTE_FUNCTION_ARGS): Remove.
7926 (PROMOTE_FUNCTION_RETURN): Likewise.
7927 (RETURN_IN_MEMORY): Likewise.
7928 (STRUCT_VALUE): Likewise.
7930 2004-01-26 Richard Henderson <rth@redhat.com>
7932 * c-parse.in (extension): Use itype.
7933 (SAVE_EXT_FLAGS): Don't allocate a tree.
7934 (RESTORE_EXT_FLAGS): Don't read a tree.
7936 2004-01-26 Jan Hubicka <jh@suse.cz>
7938 * cselib.c (discard_useless_values): Clear out value pointer pointing
7939 to datastructure to be recycled.
7941 2004-01-25 Jan Hubicka <jh@suse.cz>
7943 * genextract.c (main): Do not output the memset when not checking.
7945 2004-01-26 Kazu Hirata <kazu@cs.umass.edu>
7947 * config/h8300/h8300.c (h8300_tiny_constant_address_p): Use a
7948 switch statement instead of a chain of if statements.
7950 2004-01-26 Jeff Law <law@redhat.com>
7952 * doc/contrib.texi: Minor cleanup for Paolo Carlini's entry. Add
7953 acute accents for Petur Runolfsson's entry.
7955 2004-01-26 Kazu Hirata <kazu@cs.umass.edu>
7957 * config/pdp11/pdp11.c (TARGET_STRUCT_VALUE_RTX): New.
7958 (TARGET_RETURN_IN_MEMORY): Likewise.
7959 * config/pdp11/pdp11.h (STRUCT_VALUE): Remove.
7960 (RETURN_IN_MEMORY): Likewise.
7962 2004-01-26 Fariborz Jahanian <fjahanian@apple.com>
7964 * config/rs6000/rs6000.c (rs6000_emit_move): split slow
7965 unaligned load/store into smaller loads and stores.
7967 2004-01-26 Fariborz Jahanian <fjahanian@apple.com>
7969 * function.c (assign_parms): Do not assign
7970 long long argument to memory in prologue if
7971 is it loaded into register.
7973 2004-01-26 Fariborz Jahanian <fjahanian@apple.com>
7976 * expr.c (emit_group_load): split constant
7977 correctly into register components of PARALLEL insn.
7979 2004-01-26 Fariborz Jahanian <fjahanian@apple.com>
7981 * gcc/config/rs6000/rs6000.md (save_stack_nonlocal):
7982 Use adjust_address_nv directly with appropriate mode.
7983 (restore_stack_nonlocal): Ditto.
7985 2004-01-26 Kazu Hirata <kazu@cs.umass.edu>
7987 * config/xtensa/xtensa-protos.h: Remove the prototype for
7988 xtensa_builtin_saveregs.
7989 * config/xtensa/xtensa.c (TARGET_PROMOTE_FUNCTION_ARGS): New.
7990 (TARGET_PROMOTE_FUNCTION_RETURN): Likewise.
7991 (TARGET_PROMOTE_PROTOTYPES): Likewise.
7992 (TARGET_STRUCT_VALUE_RTX): Likewise.
7993 (TARGET_RETURN_IN_MEMORY): Likewise.
7994 (TARGET_EXPAND_BUILTIN_SAVEREGS): Likewise.
7995 (xtensa_builtin_saveregs): Make it static.
7996 (xtensa_return_in_memory): New.
7997 * config/xtensa/xtensa.h (PROMOTE_FUNCTION_ARGS: Remove.
7998 (PROMOTE_FUNCTION_RETURN): Likewise.
7999 (PROMOTE_PROTOTYPES): Likewise.
8000 (STRUCT_VALUE): Likewise.
8001 (RETURN_IN_MEMORY): Likewise.
8002 (EXPAND_BUILTIN_SAVEREGS): Likewise.
8004 2004-01-26 Kazu Hirata <kazu@cs.umass.edu>
8006 * config/arm/arm.c (TARGET_SETUP_INCOMING_VARARGS): New.
8007 (arm_setup_incoming_varargs): Likewise.
8008 * config/arm/arm.h (SETUP_INCOMING_VARARGS): Remove.
8010 2004-01-26 Kazu Hirata <kazu@cs.umass.edu>
8012 * config/cris/cris.c (TARGET_SETUP_INCOMING_VARARGS): New.
8013 (cris_setup_incoming_varargs): Likewise.
8014 * config/cris/cris.h (SETUP_INCOMING_VARARGS): Remove.
8016 2004-01-26 Kazu Hirata <kazu@cs.umass.edu>
8018 * config/ns32k/ns32k.c (TARGET_STRUCT_VALUE_RTX): New.
8019 (ns32k_struct_value_rtx): Likewise.
8020 * config/ns32k/ns32k.h (STRUCT_VALUE_REGNUM): Rename to
8021 NS32K_STRUCT_VALUE_REGNUM.
8023 2004-01-26 Kazu Hirata <kazu@cs.umass.edu>
8025 * config/arm/arm.c (TARGET_PROMOTE_FUNCTION_ARGS): New.
8026 (TARGET_PROMOTE_PROTOTYPES): Likewise.
8027 (TARGET_STRUCT_VALUE_RTX): Likewise.
8028 (arm_struct_value_rtx): Likewise.
8029 * config/arm/arm.h (PROMOTE_FUNCTION_ARGS): Remove.
8030 (STRUCT_VALUE): Likewise.
8031 (STRUCT_VALUE_REGNUM): Likewise.
8032 (PROMOTE_PROTOTYPES): Likewise.
8034 2004-01-26 Kazu Hirata <kazu@cs.umass.edu>
8036 * config/ia64/ia64-protos.h: Remove the prototype for
8037 ia64_setup_incoming_varargs and ia64_return_in_memory.
8038 * config/ia64/ia64.c (TARGET_STRUCT_VALUE_RTX): New.
8039 (TARGET_RETURN_IN_MEMORY): Likewise.
8040 (TARGET_SETUP_INCOMING_VARARGS): Likewise.
8041 (TARGET_STRICT_ARGUMENT_NAMING): Likewise.
8042 (ia64_setup_incoming_varargs): Adjust the arguments to meet
8043 the requirement of TARGET_SETUP_INCOMING_VARARGS.
8044 (ia64_return_in_memory): Make it static. Change the return
8045 type to bool from int. Add an argument.
8046 (ia64_struct_value_rtx): New.
8047 * config/ia64/ia64.h: Remove commented-out definitions of
8048 PROMOTE_FUNCTION_ARGS, PROMOTE_FUNCTION_RETURN, and
8050 (RETURN_IN_MEMORY): Remove.
8051 (STRUCT_VALUE_REGNUM): Likewise.
8052 (STRICT_ARGUMENT_NAMING): Likewise.
8054 2004-01-26 Eric Botcazou <ebotcazou@libertysurf.fr>
8057 * config/sparc/sparc.c (function_arg_union_value): New function.
8058 (function_arg): Use it to deal with unions.
8059 (function_value): Likewise. Define 'regbase' only for ARCH64.
8060 Replace a conditional statement by a simpler one.
8062 2004-01-26 Richard Sandiford <rsandifo@redhat.com>
8064 * config/mips/mips.c (mips16_optimize_gp): Delete.
8065 (mips_reorg): Don't call it.
8067 2004-01-26 Michael Hayes <m.hayes@elec.canterbury.ac.nz>
8069 * config/c4x/c4x.md (addqi3_noclobber): Move up pecking order.
8070 (floatunsqihf2): Remove operand 6.
8071 (fixhfqi_set, fix_trunchfqi2, fixuns_trunchfqi2): Group with other
8073 (ldi_conditional, ldf_conditional): Validate operands.
8075 2004-01-26 Michael Hayes <m.hayes@elec.canterbury.ac.nz>
8077 * config/c4x/c4x.h (BCT_CHECK_LOOP_ITERATIONS): Remove.
8078 (HAVE_GAS_HIDDEN): Undefine as interim measure.
8080 2004-01-26 Michael Hayes <m.hayes@elec.canterbury.ac.nz>
8082 * config/c4x/c4x.c (c4x_legitimate_address_p): Invalidate direct
8083 memory references if TARGET_EXPOSE_LDP nonzero.
8085 2004-01-26 Michael Hayes <m.hayes@elec.canterbury.ac.nz>
8087 * config/c4x/c4x.c (legitimize_operands): Truncate invalid shift counts.
8089 2004-01-26 Michael Hayes <m.hayes@elec.canterbury.ac.nz>
8091 * config/c4x/c4x.c (c4x_valid_operands): More aggressively reject
8092 invalid operand combinations.
8094 2004-01-26 Michael Hayes <m.hayes@elec.canterbury.ac.nz>
8096 * config/c4x/c4x.c (c4x_check_legit_addr): Rename to
8097 c4x_legitimate_address_p. Fix post_modify check.
8099 * config/c4x/c4x-protos.h (c4x_check_legit_addr): Adjust.
8100 * config/c4x/c4x.h (c4x_check_legit_addr): Adjust.
8102 2004-01-25 Kazu Hirata <kazu@cs.umass.edu>
8104 * config/pa/pa-protos.h: Remove the prototype for
8105 hppa_builtin_saveregs. Add a prototype for
8106 pa_return_in_memory.
8107 * config/pa/pa.c (TARGET_PROMOTE_FUNCTION_RETURN): New.
8108 (TARGET_PROMOTE_PROTOTYPES): Likewise.
8109 (TARGET_STRUCT_VALUE_RTX): Likewise.
8110 (TARGET_RETURN_IN_MEMORY): Likewise.
8111 (TARGET_EXPAND_BUILTIN_SAVEREGS): Likewise.
8112 (pa_struct_value_rtx): Likewise.
8113 (pa_return_in_memory): Likewise.
8114 * config/pa/pa.h (STRUCT_VALUE_REGNUM): Rename to
8115 PA_STRUCT_VALUE_REGNUM.
8116 (INIT_CUMULATIVE_ARGS): Use pa_return_in_memory.
8117 (EXPAND_BUILTIN_SAVEREGS): Remove.
8118 (PROMOTE_PROTOTYPES): Likewise.
8119 (PROMOTE_FUNCTION_RETURN): Likewise.
8121 2004-01-25 Kazu Hirata <kazu@cs.umass.edu>
8123 * config/vax/vax.c (TARGET_PROMOTE_PROTOTYPES): New.
8124 (TARGET_STRUCT_VALUE_RTX): Likewise.
8125 (vax_struct_value_rtx): Likewise.
8126 * config/vax/vax.h (STRUCT_VALUE_REGNUM): Rename to
8127 VAX_STRUCT_VALUE_REGNUM.
8128 (PROMOTE_PROTOTYPES): Remove.
8130 2004-01-26 Michael Hayes <m.hayes@elec.canterbury.ac.nz>
8132 * config/c4x/c4x.h (LEGITIMIZE_RELOAD_ADDRESS): Handle symref.
8134 2003-04-25 Chris Demetriou <cgd@broadcom.com>
8136 * config/mips/mips.h (ISA_HAS_HILO_INTERLOCKS): MIPS32, MIPS32r2,
8137 and MIPS64 have HI/LO interlocks. Update comment.
8139 2004-01-25 Kazu Hirata <kazu@cs.umass.edu>
8141 * config/stormy16/stormy16-protos.h: Remove the prototype for
8142 xstormy16_setup_incoming_varargs.
8143 * config/stormy16/stormy16.c
8144 (xstormy16_setup_incoming_varargs): Remove.
8145 (xstormy16_return_in_memory): New.
8146 (TARGET_PROMOTE_FUNCTION_ARGS): Likewise.
8147 (TARGET_PROMOTE_FUNCTION_RETURN): Likewise.
8148 (TARGET_PROMOTE_PROTOTYPES): Likewise.
8149 (TARGET_STRUCT_VALUE_RTX): Likewise.
8150 (TARGET_RETURN_IN_MEMORY): Likewise.
8151 * config/stormy16/stormy16.h (PROMOTE_FUNCTION_ARGS): Remove.
8152 (PROMOTE_FUNCTION_RETURN): Likewise
8153 (PROMOTE_PROTOTYPES): Likewise
8154 (RETURN_IN_MEMORY): Likewise
8155 (STRUCT_VALUE): Likewise
8156 (SETUP_INCOMING_VARARGS): Likewise
8158 2004-01-25 Richard Sandiford <rsandifo@redhat.com>
8160 * config/mips/mips.c (mips_offset_within_object_p): New function.
8161 (mips_symbolic_constant_p): Use it in the SYMBOL_SMALL_DATA and
8162 SYMBOL_CONSTANT_POOL cases. Also use it for SYMBOL_GENERAL if the
8163 ABI has 64-bit pointers and the object file only allows 32-bit symbols.
8165 2004-01-25 Kazu Hirata <kazu@cs.umass.edu>
8167 * config/sh/sh.h (PROMOTE_FUNCTION_ARGS): Remove.
8168 (PROMOTE_FUNCTION_RETURN): Likewise.
8170 2004-01-25 Kazu Hirata <kazu@cs.umass.edu>
8172 * config/mn10300/mn10300-protos.h: Remove the prototype for
8173 mn10300_builtin_saveregs.
8174 * config/mn10300/mn10300.c (TARGET_PROMOTE_PROTOTYPES): New.
8175 (TARGET_STRUCT_VALUE_RTX): Likewise.
8176 (TARGET_RETURN_IN_MEMORY): Likewise.
8177 (TARGET_EXPAND_BUILTIN_SAVEREGS): Likewise.
8178 (mn10300_return_in_memory): Likewise.
8179 (mn10300_builtin_saveregs): Make it static.
8180 * config/mn10300/mn10300.h (PROMOTE_PROTOTYPES): Remove.
8181 (RETURN_IN_MEMORY): Likewise.
8182 (STRUCT_VALUE): Likewise.
8183 (EXPAND_BUILTIN_SAVEREGS): Likewise.
8185 2004-01-25 Eric Botcazou <ebotcazou@act-europe.fr>
8188 * cfgcleanup.c (try_optimize_cfg): Explicitly test against 0.
8190 2004-01-25 Kazu Hirata <kazu@cs.umass.edu>
8192 * config/h8300/lib1funcs.asm (divnorm, modnorm): Optimize by
8195 2004-01-25 Kazu Hirata <kazu@cs.umass.edu>
8197 * config/i860/i860-protos.h: Remove the prototype for
8199 * config/i860/i860.c (i860_saveregs): Make it static.
8200 (i860_struct_value_rtx): New.
8201 (TARGET_STRUCT_VALUE_RTX): Likewise.
8202 (TARGET_EXPAND_BUILTIN_SAVEREGS): Likewise.
8203 * config/i860/i860.h (STRUCT_VALUE_REGNUM): Rename to
8204 I860_STRUCT_VALUE_REGNUM.
8205 (EXPAND_BUILTIN_SAVEREGS): Remove.
8207 2004-01-25 Kazu Hirata <kazu@cs.umass.edu>
8209 * config/m68hc11/m68hc11.c (TARGET_STRUCT_VALUE_RTX): New.
8210 (TARGET_RETURN_IN_MEMORY): Likewise.
8211 (m68hc11_struct_value_rtx): Likewise.
8212 (m68hc11_return_in_memory): Likewise.
8213 * config/m68hc11/m68hc11.h: Remove a commented-out definition
8214 of PROMOTE_PROTOTYPES.
8215 (RETURN_IN_MEMORY): Remove.
8216 (STRUCT_VALUE_REGNUM): Likewise.
8218 2004-01-25 Kazu Hirata <kazu@cs.umass.edu>
8220 * config/mmix/mmix-protos.h: Remove the prototype for
8221 mmix_setup_incoming_varargs.
8222 * config/mmix/mmix.c (TARGET_PROMOTE_FUNCTION_ARGS): New.
8223 (TARGET_STRUCT_VALUE_RTX): Likewise.
8224 (TARGET_SETUP_INCOMING_VARARGS): Likewise.
8225 (mmix_setup_incoming_varargs): Make it static.
8226 (mmix_struct_value_rtx): New.
8227 * config/mmix/mmix.h (PROMOTE_FUNCTION_ARGS): Remove.
8228 Remove a commented-out definition of PROMOTE_FUNCTION_RETURN.
8229 (STRUCT_VALUE_REGNUM): Remove.
8230 (SETUP_INCOMING_VARARGS): Likewise.
8232 2004-01-25 Kazu Hirata <kazu@cs.umass.edu>
8234 * config/mips/mips-protos.h: Remove the prototypes for
8235 mips_setup_incoming_varargs and mips_return_in_memory.
8236 * config/mips/mips.c (TARGET_PROMOTE_FUNCTION_ARGS): New.
8237 (TARGET_PROMOTE_FUNCTION_RETURN): Likewise.
8238 (TARGET_PROMOTE_PROTOTYPES): Likewise.
8239 (TARGET_STRUCT_VALUE_RTX): Likewise.
8240 (TARGET_RETURN_IN_MEMORY): Likewise.
8241 (TARGET_SETUP_INCOMING_VARARGS): Likewise.
8242 (TARGET_STRICT_ARGUMENT_NAMING): Likewise.
8243 (mips_setup_incoming_varargs): Match the prototype for
8244 TARGET_SETUP_INCOMING_VARARGS.
8245 (mips_return_in_memory): Make it static. Add argument fntype.
8246 (mips_strict_argument_naming): New.
8247 * config/mips/mips.h (PROMOTE_PROTOTYPES): Remove.
8248 (PROMOTE_FUNCTION_ARGS): Likewise.
8249 (PROMOTE_FUNCTION_RETURN): Likewise.
8250 (STRUCT_VALUE): Likewise.
8251 (RETURN_IN_MEMORY): Likewise.
8252 (SETUP_INCOMING_VARARGS): Likewise.
8253 (STRICT_ARGUMENT_NAMING): Likewise.
8255 2004-01-25 Kazu Hirata <kazu@cs.umass.edu>
8257 * config/ip2k/ip2k.c (TARGET_STRUCT_VALUE_RTX): New.
8258 (TARGET_RETURN_IN_MEMORY): Likewise.
8259 (TARGET_SETUP_INCOMING_VARARGS): Likewise.
8260 (ip2k_return_in_memory): Likewise.
8261 (ip2k_setup_incoming_varargs): Likewise.
8262 * config/ip2k/ip2k.h (RETURN_IN_MEMORY): Remove.
8263 (STRUCT_VALUE): Likewise.
8264 (STRUCT_VALUE_INCOMING): Likewise.
8265 (SETUP_INCOMING_VARARGS): Likewise.
8267 2004-01-25 Kazu Hirata <kazu@cs.umass.edu>
8269 * config/avr/avr.c (TARGET_STRUCT_VALUE_RTX): New.
8270 (TARGET_RETURN_IN_MEMORY): Likewise.
8271 (TARGET_STRICT_ARGUMENT_NAMING): Likewise.
8272 (avr_return_in_memory): Remove.
8273 * config/avr/avr.h (RETURN_IN_MEMORY): Remove.
8274 (STRUCT_VALUE): Likewise.
8275 (STRUCT_VALUE_INCOMING): Likewise.
8276 (STRICT_ARGUMENT_NAMING): Likewise.
8278 2004-01-25 Jan Hubicka <jh@suse.cz>
8280 * combine.c (recog_for_combine): Avoid allocating unnecesary RTX.
8282 2004-01-25 Richard Sandiford <rsandifo@redhat.com>
8284 * config/mips/mips-protos.h (mips_reg_mode_ok_for_base_p): Delete.
8285 (mips_regno_mode_ok_for_base_p): Declare.
8286 * config/mips/mips.h (ARG_POINTER_REGNUM): Renumber to 77.
8287 (FRAME_POINTER_REGNUM): Renumber to 78.
8288 (FIRST_PSEUDO_REGISTER): Update comment accordingly.
8289 (BASE_REG_P, GP_REG_OR_PSEUDO_STRICT_P): Delete.
8290 (GP_REG_OR_PSEUDO_NONSTRICT_P): Delete.
8291 (REGNO_MODE_OK_FOR_BASE_P): Use mips_regno_mode_ok_for_base_p.
8292 (REG_MODE_OK_FOR_BASE_P): Likewise.
8293 * config/mips/mips.c (mips_reg_names, mips_sw_reg_names): Change
8294 entry for 77 to "$arg" and entry for 78 to "$frame".
8295 (mips_regno_to_class): Map 77 and 78 to ALL_REGS.
8296 (mips_reg_mode_ok_for_base_p): Remove.
8297 (mips_regno_mode_ok_for_base_p): New function, derived from old
8298 BASE_REG_P macro. Don't enforce the mips16 stack pointer
8299 restrictions unless we're being strict.
8300 (mips_valid_base_register_p): Use mips_regno_mode_ok_for_base_p.
8302 2004-01-24 Kazu Hirata <kazu@cs.umass.edu>
8304 * c-common.h: Fix comment typos.
8305 * c-decl.c: Likewise.
8306 * cgraphunit.c: Likewise.
8307 * combine.c: Likewise.
8308 * et-forest.c: Likewise.
8310 * function.c: Likewise.
8311 * ifcvt.c: Likewise.
8312 * integrate.c: Likewise.
8314 * postreload.c: Likewise.
8315 * varray.c: Likewise.
8317 2004-01-24 Kazu Hirata <kazu@cs.umass.edu>
8319 * doc/frontends.texi: Update copyright.
8320 * doc/gcov.texi: Likewise.
8321 * doc/gty.texi: Likewise.
8322 * doc/sourcebuild.texi: Likewise.
8323 * doc/standards.texi: Likewise.
8325 2004-01-24 Herman A.J. ten Brugge <hermantenbrugge@home.nl>
8328 * c4x.md: (movstrqi*) Use match_scratch instead of match_dup.
8329 Remove movstrqi_small because it conflicts with movstrqi_large.
8331 2004-01-24 Kazu Hirata <kazu@cs.umass.edu>
8333 * config/cris/cris.c (TARGET_PROMOTE_FUNCTION_ARGS): New.
8334 (TARGET_STRUCT_VALUE_RTX): Likewise.
8335 (cris_struct_value_rtx): Likewise.
8336 * config/cris/cris.h (PROMOTE_FUNCTION_ARGS): Remove.
8337 (CRIS_STACKADJ_REG): Use CRIS_STRUCT_VALUE_REGNUM instead of
8338 STRUCT_VALUE_REGNUM.
8339 (STRUCT_VALUE_REGNUM): Rename to CRIS_STRUCT_VALUE_REGNUM.
8341 2004-01-24 Ian Lance Taylor <ian@wasabisystems.com>
8344 * cse.c (cse_cc_succs): Change the mode of the source expression
8345 as soon as decide we need a new mode. Don't permit changing modes
8346 if we found a match in a successor block.
8347 (cse_condition_code_reg): Save original mode of source expression
8348 so that we know whether we have to change the mode in other
8351 2004-01-24 Jan Hubicka <jh@suse.cz>
8353 * emit-rtl.c (change_address, adjust_address_1, offset_address,
8354 widen_memory_access): Return early when there is nothing to change.
8356 2004-01-24 Jakub Jelinek <jakub@redhat.com>
8358 * simplify-rtx.c (simplify_relational_operation): Don't
8359 simplify address == constant into address + -constant == 0.
8361 2004-01-24 Kazu Hirata <kazu@cs.umass.edu>
8363 * gcc.c (process_command): Don't internationalize the
8365 * mips-tfile.c (main): Likewise.
8367 2004-01-24 Andreas Tobler <a.tobler@schweiz.ch>
8369 * cse.c: (cse_cc_succs) Fix comparison warning.
8371 2004-01-24 Kazu Hirata <kazu@cs.umass.edu>
8373 * config/h8300/h8300.md: Remove extraneous USE in expanders.
8375 2004-01-24 Kazu Hirata <kazu@cs.umass.edu>
8377 * config/h8300/h8300-protos.h: Provide prototypes for
8378 h8300_legitimate_constant_p and h8300_legitimate_address_p.
8379 * config/h8300/h8300.c (h8300_legitimate_constant_p): New.
8380 (h8300_rtx_ok_for_base_p): Likewise.
8381 (h8300_legitimate_address_p): Likewise.
8382 * config/h8300/h8300.h (LEGITIMATE_CONSTANT_P): Use
8383 h8300_legitimate_constant_p.
8384 (RTX_OK_FOR_BASE_P): Remove.
8385 (GO_IF_LEGITIMATE_ADDRESS): Use h8300_legitimate_address_p.
8387 2004-01-24 Kazu Hirata <kazu@cs.umass.edu>
8389 * config/h8300/h8300.h (REG_OK_FOR_INDEX_NONSTRICT_P): New.
8390 (REG_OK_FOR_BASE_NONSTRICT_P): Likewise.
8391 (REG_OK_FOR_INDEX_STRICT_P): Likewise.
8392 (REG_OK_FOR_BASE_STRICT_P): Likewise.
8393 (REG_OK_FOR_INDEX_STRICT_P): Use REGNO_OK_FOR_INDEX_P.
8394 (REG_OK_FOR_BASE_STRICT_P): Use REGNO_OK_FOR_BASE_P.
8395 (REG_OK_FOR_INDEX_P): Use REG_OK_FOR_INDEX_STRICT_P.
8396 (REG_OK_FOR_BASE_P): Use REG_OK_FOR_BASE_STRICT_P.
8398 2004-01-24 Jan Hubicka <jh@suse.cz>
8400 * cselib.c (remove_useless_values): Do not access discarded values.
8402 2004-01-24 Joseph S. Myers <jsm@polyomino.org.uk>
8404 * c-typeck.c (build_conditional_expr): Do not allow non-lvalue
8407 2004-01-23 Kazu Hirata <kazu@cs.umass.edu>
8409 * recog.c: Fix a typo in copyright.
8411 2004-01-23 Andrew Pinski <apinski@apple.com>
8413 * config/rs6000/rs6000.md (call): Fix misappiled patch.
8414 (call_value): Likewise.
8416 2004-01-23 Richard Henderson <rth@redhat.com>
8419 * combine.c (SHIFT_COUNT_TRUNCATED): Provide default value.
8420 (simplify_comparison): Don't simplify (eq (zero_extract c 1 r) 0)
8421 if SHIFT_COUNT_TRUNCATED is set.
8423 2004-01-23 Bob Wilson <bob.wilson@acm.org>
8425 * config/xtensa/xtensa.c (xtensa_va_arg): Handle complex values as
8426 separate real and imaginary parts.
8427 * config/xtensa/xtensa.h (SPLIT_COMPLEX_ARGS): Define.
8429 2004-01-23 Hartmut Penner <hpenner@de.ibm.com>
8432 * config/rs6000/rs6000.md (movdf_hardfloat64): Do not disparage
8435 2004-01-23 Jan Hubicka <jh@suse.cz>
8437 * emit-rtl.c (change_address_1): Do not re-generate the RTX if nothing
8440 * alloc-pool.c (align_four): Kill.
8441 (create_alloc_pool): Align size to eight.
8442 (free_alloc_pool, free_pool): Invalidate deallocated data.
8444 2004-01-23 Ian Lance Taylor <ian@wasabisystems.com>
8447 * cse.c (cse_change_cc_mode): New static function.
8448 (cse_change_cc_mode_insns, cse_cc_succs): Likewise.
8449 (cse_condition_code_reg): New function.
8450 * rtl.h (cse_condition_code_reg): Declare.
8451 * toplev.c (rest_of_handle_cse2): Call cse_condition_code_reg.
8452 * target.h (struct gcc_target): Add fixed_condition_code_regs and
8453 cc_modes_compatible.
8454 * target-def.h (TARGET_FIXED_CONDITION_CODE_REGS): Define.
8455 (TARGET_CC_MODES_COMPATIBLE): Define.
8456 (TARGET_INITIALIZER): Add new initializers.
8457 * targhooks.c (default_cc_modes_compatible): New function.
8458 * targhooks.c (default_cc_modes_compatible): Declare.
8459 * hooks.c (hook_bool_intp_intp_false): New function.
8460 * hooks.h (hook_bool_intp_intp_false): Declare.
8461 * config/i386/i386.c (TARGET_FIXED_CONDITION_CODE_REGS): Define.
8462 (TARGET_CC_MODES_COMPATIBLE): Define.
8463 (ix86_fixed_condition_code_regs): New static function.
8464 (ix86_cc_modes_compatible): Likewise.
8465 * doc/tm.texi (Condition Code): Document new hooks.
8467 2004-01-23 Rainer Orth <ro@TechFak.Uni-Bielefeld.DE>
8469 * fixinc/inclhack.def (bad_lval): Renamed to ...
8470 (alpha_bad_lval): ... this.
8472 Restrict to alpha*-dec-osf*.
8473 * fixinc/fixincl.x: Regenerate.
8474 * fixinc/tests/base/dirent.h: Remove, moving test ...
8475 * fixinc/tests/base/testing.h: ... here, reflecting new name.
8477 2004-01-23 Zack Weinberg <zack@codesourcery.com>
8480 * c-decl.c (diagnose_mismatched_decls): Also discard a
8481 built-in if we encounter an old-style definition with the
8484 2004-01-23 Jakub Jelinek <jakub@redhat.com>
8486 * config.gcc (powerpc*-*): Clear $with_cpu or $with_tune if it was
8487 set to default{32,64}.
8489 2004-01-21 Jakub Jelinek <jakub@redhat.com>
8491 * config/rs6000/linux64.h (MD_FALLBACK_FRAME_STATE_FOR)
8492 [!__powerpc64__]: Corrected to handle kernels with changed ucontext.
8494 2004-01-23 Eric Botcazou <ebotcazou@act-europe.fr>
8495 Olivier Hainque <hainque@act-europe.fr>
8497 * fold-const.c (fold_binary_op_with_conditional_arg): Only
8498 build a COMPOUND_EXPR if 'arg' is really a SAVE_EXPR.
8500 2004-01-23 Daniel Jacobowitz <drow@mvista.com>
8502 * config/arm/arm.c (arm_legitimate_address_p): Don't check the mode
8503 size for minipool references.
8505 2004-01-23 Roger Sayle <roger@eyesopen.com>
8507 * real.c (real_floor, real_ceil): Tweak to allow input and output
8508 arguments to overlap.
8509 (real_round): New function to implement round(3m) semantics.
8510 * real.h (real_round): Prototype here.
8511 * builtins.c (fold_builtin_round): New function to constant fold
8512 round, roundf and roundl.
8513 (fold_builtin): Call fold_builtin_round for BUILT_IN_ROUND{,F,L}.
8515 2004-01-23 Alexandre Oliva <aoliva@redhat.com>
8517 PR optimization/13819
8518 * config/sh/sh.c (sh_reorg): Compensate for sharing of CLOBBERs
8519 introduced by 2004-01-20's Jan Hubicka's copy_insn change.
8520 (sh_handle_sp_switch_attribute): Remove warning.
8522 2003-11-30 Jan Hubicka <jh@suse.cz>
8524 * i386.c (ix86_emit_restore_regs_using_mov): Deal with large offsets.
8526 2004-01-23 J"orn Rennecke <joern.rennecke@superh.com>
8528 * doc/tm.texi: Insert some weasel words when LOAD_EXTEND_OP
8529 may or may not return non-NIL.
8530 * postreload.c (reload_cse_simplify_operands): In LOAD_EXTEND_OP code,
8531 check CANNOT_CHANGE_MODE_CLASS
8533 2004-01-23 Jan Hubicka <jh@suse.cz>
8535 * basic-block.h (PROP_POSTRELOAD): New macro.
8536 (CLEANUP_LOG_LINKS): New.
8537 * cfgcleanup.c (cleanup_cfg): Only PROP_LOG_LINKS when asked to.
8538 * toplev.c (rest_of_handle_life): Preserve LOG_LINKS trought cleanup_cfg.
8540 * cselib.c (value_pool): New.
8541 (new_cselib_val): Use pool.
8542 (cselib_init): Initialize value_pool
8543 (cselib_finish): Free pool.
8545 2004-01-23 Eric Botcazou <ebotcazou@libertysurf.fr>
8547 * config/sparc/sparc.c (scan_record_type): New function.
8548 (function_arg_slotno): Use it to determine which kinds of
8549 registers the record can be passed in.
8551 2004-01-22 James A. Mmorrison <ja2morri@uwaterloo.ca>
8553 * config/pa/fptr.c: Fix old-style definition.
8555 2004-01-22 Paolo Bonzini <bonzini@gnu.org>
8557 PR optimization/13724
8558 * cse.c (fold_rtx) <SUBREG>: Fold a SUBREG to zero if it
8559 represents the zero bits produced by a ZERO_EXTEND operation.
8561 2004-01-22 Roger Sayle <roger@eyesopen.com>
8563 PR optimization/13821
8564 * simplify-rtx.c (simplify_subreg): Use subreg_lowpart_offset to
8565 correctly calculate the lowpart offset of the contracted subreg.
8567 2004-01-22 Ian Lance Taylor <ian@wasabisystems.com>
8569 * doc/invoke.texi (Optimize Options): Note that --param arguments
8570 are subject to change without notice.
8572 2004-01-22 Rainer Orth <ro@TechFak.Uni-Bielefeld.DE>
8574 * config.gcc (mips-sgi-irix6*o32): Removed.
8575 * config/mips/iris6-o32-as.h: Likewise.
8576 * config/mips/iris6-o32-gas.h: Likewise.
8577 * config/mips/iris6-o32.h: Likewise.
8579 2004-01-22 Jan Hubicka <jh@suse.cz>
8581 * cfgcleanup.c (first_pass): New static variable.
8582 (try_forward_edges): Add work limiting check for threading.
8583 (try_crossjump_bb): Add work limiting check for crossjumping.
8584 (try_optimize_cfg): Maintain first pass variable.
8586 2004-01-22 Bob Wilson <bob.wilson@acm.org>
8588 * config/xtensa/xtensa.c (function_arg): Generalize logic so that it
8589 handles complex and vector modes.
8591 2004-01-22 Kazu Hirata <kazu@cs.umass.edu>
8593 * config/h8300/h8300.h (REG_OK_FOR_INDEX_P_STRICT): Remove.
8594 (REG_OK_FOR_BASE_P_STRICT): Likewise.
8597 2004-01-22 Daniel Jacobowitz <drow@mvista.com>
8599 * c-semantics.c (genrtl_while_stmt, genrtl_do_stmt_1)
8600 (genrtl_for_stmt): Remove emit_nop calls.
8602 2004-01-22 John David Anglin <dave.anglin@nrc-cnrc.gc.ca>
8606 * pa.md (movstrsi_prereload, movstrsi_postreload, movstrdi_prereload,
8607 movstrdi_postreload, clrstrsi_prereload, clrstrsi_postreload,
8608 clrstrdi_prereload, clrstrdi_postreload): Fix constraints.
8610 2004-01-22 Daniel Jacobowitz <drow@mvista.com>
8612 * config/arm/arm.c: Include "debug.h".
8613 (thumb_pushpop): Take two new arguments. Add some commentary.
8614 Output frame information when pushing.
8615 (thumb_exit, thumb_unexpanded_epilogue): Update calls to
8617 (thumb_output_function_prologue): Likewise. Accumulate a CFA
8618 offset, and pass it to thumb_pushpop. Output CFI information.
8619 (thumb_expand_prologue): Add some frame-related markers and notes.
8621 2004-01-22 Ulrich Weigand <uweigand@de.ibm.com>
8623 * config/s390/s390.c (s390_frame_info): Allow large frame sizes
8625 (s390_arg_frame_offset): Change return type to HOST_WIDE_INT.
8626 * config/s390/s390-protos.h (s390_arg_frame_offset): Likewise.
8628 2004-01-22 Roger Sayle <roger@eyesopen.com>
8629 Paolo Bonzini <bonzini@gnu.org>
8631 * rtlanal.c (subreg_lsb_1): New function split out from subreg_lsb.
8632 (subreg_lsb): Change to call new subreg_lsb_1 helper function.
8633 * rtl.h (subreg_lsb_1): Prototype here.
8634 * simplify-rtx.c (simplify_subreg): Optimize subregs of zero and
8637 2004-01-22 Kazu Hirata <kazu@cs.umass.edu>
8639 * doc/tm.texi (CASE_VECTOR_PC_RELATIVE): Mention that the
8640 macro need not be defined if jump-tables should contain
8641 relative addresses only when -fPIC or -fPIC is in effect.
8643 2004-01-22 Jan Hubicka <jh@suse.cz>
8645 * alias.c (reg_base_value): Turn into varray.
8646 (reg_base_value_size): Kill.
8647 (old_reg_base_value): New deletable varray.
8648 (alias_invariant_size): New variable.
8649 (REG_BASE_VALUE): Update to use varray.
8650 (find_base_value): Likewise.
8651 (record_set): Likewise.
8652 (record_base_value): Likewise.
8653 (memrefs_conflict_p): Likewise.
8654 (record_set): Likewise
8655 (record_base_value): Likewise.
8656 (memrefs_conflict_p): Use alias_invariant_size.
8657 (init_alias_analysis): Use varray; set alias_invariant_size;
8658 rescale other arrays to be sized by maxreg.
8659 (end_alias_analysis): Save reg_base_value; clear alias_invariant_size.
8661 2004-01-22 Eric Botcazou <ebotcazou@libertysurf.fr>
8663 * config/sparc/sparc.c (function_arg_slotno): Use
8664 FLOAT_TYPE_P to detect FP fields in structures.
8665 (function_arg_record_value_1): Likewise.
8666 (function_arg_record_value_2): Likewise.
8668 2004-01-22 Jan Hubicka <jh@suse.cz>
8670 * function.c (allocate_struct_function): Do not initialize expr, emit
8672 (prepare_function_start): Do it here.
8673 * c-parse.in (maybe_type_qual): Do not produce line number notes.
8675 2004-01-22 Eric Botcazou <ebotcazou@libertysurf.fr>
8678 * config/sparc/sparc.c (function_arg_record_value_3): Revert
8679 to 'word_mode' once the first slot has been filled.
8681 2004-01-22 Olivier Hainque <hainque@act-europe.fr>
8683 * config/sparc/sparc.c (function_arg_record_value_1): Fix
8684 computation of the number of integer registers required.
8686 2004-01-21 Kazu Hirata <kazu@cs.umass.edu>
8688 * config/i386/i386.md: Simplify certain comparisons of
8691 2004-01-21 Andrew Pinski <apinski@apple.com>
8694 * config/rs6000/rs6000.md (call_value): Force operand
8695 1 not operand 0 into a register.
8697 2004-01-21 Kazu Hirata <kazu@cs.umass.edu>
8699 * cpperror.c, cpptrad.c, longlong.h, params.def, rtl.def,
8700 unwind-dw2-fde.h: Update copyright.
8702 2004-01-21 John David Anglin <dave.anglin@nrc-cnrc.gc.ca>
8704 * pa-protos.h: Update copyright.
8708 2004-01-21 Caroline Tice <ctice@apple.com>
8711 * config/i386/i386.md (fix_truncxfdi2): Add clause to clobber
8713 (fix_truncdfdi2): Likewise.
8714 (fix_truncsfdi2): Likewise.
8715 (*fix_truncdi_1): Likewise.
8716 (fix_truncxfsi2): Likewise.
8717 (fix_truncdfsi2): Likewise.
8718 (fix_truncsfsi2): Likewise.
8719 (*fix_truncsi_1): Likewise.
8720 (fix_truncxfhi2): Likewise.
8721 (fix_truncdfhi2): Likewise.
8722 (fix_truncsfhi2): Likewise.
8723 (*fix_trunchi_1): Likewise.
8725 2004-01-21 Kazu Hirata <kazu@cs.umass.edu>
8727 * alias.c, basic-block.h, c-common.c, c-common.h,
8728 c-cppbuiltin.c, c-opts.c, c-pragma.c, c-pretty-print.c,
8729 calls.c, cfg.c, cfgcleanup.c, cfgrtl.c, cgraph.h, collect2.c,
8730 combine.c, cppcharset.c, cpphash.h, cppinit.c, cpplib.c,
8731 cpplib.h, cppmacro.c, crtstuff.c, cselib.c, cselib.h,
8732 defaults.h, df.c, dominance.c, et-forest.c, expmed.c, expr.c,
8733 expr.h, fix-header.c, function.h, gcc.c, gcse.c, genattrtab.c,
8734 genautomata.c, genconditions.c, genemit.c, genflags.c,
8735 gengtype.c, gengtype.h, genopinit.c, genrecog.c, gensupport.c,
8736 ggc-zone.c, graph.c, haifa-sched.c, input.h, integrate.c,
8737 langhooks-def.h, langhooks.c, langhooks.h, line-map.c,
8738 line-map.h, local-alloc.c, optabs.c, optabs.h, postreload.c,
8739 ra.h, recog.c, reg-stack.c, regmove.c, reload.c, reorg.c,
8740 rtl.c, sched-deps.c, sched-ebb.c, sdbout.c, system.h,
8741 target.h, targhooks.c, toplev.h, tree-inline.c, unwind-pe.h,
8742 unwind.h, varray.c, varray.h: Update copyright.
8744 2004-01-21 Kazu Hirata <kazu@cs.umass.edu>
8746 * config/h8300/coff.h: Update copyright.
8747 * config/h8300/elf.h: Likewise.
8748 * config/h8300/h8300-protos.h: Likewise.
8749 * config/h8300/h8300.c: Likewise.
8750 * config/h8300/h8300.h: Likewise.
8751 * config/h8300/h8300.md: Likewise.
8753 2004-01-21 John David Anglin <dave.anglin@nrc-cnrc.gc.ca>
8755 * fixinc/inclhack.def (hpux10_stdio_declarations, ultrix_const3,
8756 ultrix_locale, ultrix_stdlib, ultrix_strings, ultrix_sys_time,
8757 ultrix_unistd): New hacks.
8758 * fixinc/tests/base/stdio.h (HPUX10_STDIO_DECLARATIONS_CHECK,
8759 ULTRIX_CONST2_CHECK): Add checks.
8760 * fixinc/tests/base/stdlib.h (ULTRIX_STDLIB_CHECK): Likewise.
8761 * fixinc/tests/base/strings.h (ULTRIX_STRINGS2_CHECK): Likewise.
8762 * fixinc/tests/base/unistd.h (ULTRIX_UNISTD_CHECK): Likewise.
8763 * fixinc/tests/base/sys/time.h (ULTRIX_SYS_TIME_CHECK): Likewise.
8764 * fixinc/tests/base/locale.h: New file.
8765 * fixinc/fixincl.x: Rebuilt.
8767 2004-01-21 Andreas Jaeger <aj@suse.de>
8768 Michael Matz <matz@suse.de>
8770 * doc/extend.texi (Extended Asm): Clarify memory clobber.
8772 2004-01-21 Jakub Jelinek <jakub@redhat.com>
8774 * crtstuff.c (frame_dummy, __do_global_ctors_1): Call
8775 _Jv_RegisterClasses through a function pointer.
8777 2004-01-21 Falk Hueffner <falk@debian.org>
8780 * config/alpha/alpha.c (alpha_emit_set_const_1): If
8781 no_new_pseudos, use gen_rtx_SET directly for SImode constants
8782 which need multiple instructions to emit.
8784 2004-01-21 Inaoka Kazuhiro <inaoka.kazuhiro@renesas.com>
8786 * config/m32r/m32r.h (CPP_SPEC): Define.
8788 2004-01-21 Zack Weinberg <zack@codesourcery.com>
8790 * c-decl.c (merge_decls): Kill different_binding_level and
8791 different_tu arguments; simplify throughout.
8792 (duplicate_decls): Likewise.
8793 (pushdecl, merge_translation_unit_decls): Update calls to
8796 2004-01-20 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
8798 * Makefile.in (pretty-print.o): Depend on $(CONFIG_H) and
8800 (print-rtl1.o): Depend on $(SYSTEM_H).
8802 2004-01-20 Kelley Cook <kcook@gcc.gnu.org>
8805 * configure.ac: Delete definition and subsitution of docdir.
8806 Add info, man, srcman and srcinfo to target hooks. Create doc/
8808 * configure: Regenerate.
8809 * Makefile.in: Don't substitute docdir and delete all references
8811 (MAKEINFOFLAGS): Define.
8812 (stmp-docobjdir): Delete.
8813 (INFOFILES, MANFILES): Define.
8814 (info): Call lang.info, srcinfo and lang.srcinfo.
8815 (generated-manpages): Call lang.man, srcman and lang.srcman.
8816 (srcinfo, srcman): New rules to copy back files to source directory.
8817 (doc/%.info, doc/%.dvi, doc/%.1, doc/%.7): New implict rule.
8818 (install-man): Revamp rule.
8819 (clean): Update dvi directory.
8820 (distclean): Delete TAGS from front end directorys.
8821 (maintainer-clean): Delete all document files in source directory.
8823 objc/Make-lang.in (objc.man, objc.info): Dummy entries.
8824 (objc.srcman, objc.srcinfo): Likewise.
8826 2004-01-20 Bruce Korb <bkorb@gnu.org>
8828 * fixinc/inclhack.def(math_exception): bypass only for glibc.
8829 (matherr_decl): rename & relocate as exception_structure.
8830 This fix must precede the math_exception fix.
8832 2004-01-20 Roger Sayle <roger@eyesopen.com>
8834 * fold-const.c (fold_convert): Rename to fold_convert_const.
8835 (fold_convert_const): Change arguments to take a tree_code,
8836 a type and the operand/expression to be converted. Return
8837 NULL_TREE if no simplification is possible. Add support for
8838 FIX_CEIL_EXPR and FIX_FLOOR_EXPR in addition to FIX_TRUNC_EXPR.
8839 (fold): Handle FIX_CEIL_EXPR and FIX_FLOOR_EXPR.
8840 Adjust call to fold_convert to match new fold_convert_const.
8841 Avoid modifying the tree passed to fold in-place.
8843 2004-01-21 Alan Modra <amodra@bigpond.net.au>
8845 * config/rs6000/sysv4.h (DWARF2_FRAME_REG_OUT): Define.
8846 * dwarf2out.c (output_cfi): Map regs using DWARF2_FRAME_REG_OUT.
8847 * doc/tm.texi (DWARF_FRAME_REGNUM, DWARF2_FRAME_REG_OUT): Document.
8849 2004-01-20 John David Anglin <dave.anglin@nrc-cnrc.gc.ca>
8851 * pa-protos.h (compute_frame_size): Use HOST_WIDE_INT for frame sizes.
8852 * pa.c (store_reg, store_reg_modify, load_reg, set_reg_plus_d):
8853 Likewise. Handle frames larger than 0x7fffffff on 64-bit ports.
8854 (emit_move_sequence): Check scratch_reg first in various if statements.
8855 Extend source simplification to handle all 64-bit CONST_INTs.
8856 (pa_output_function_prologue): Use HOST_WIDE_INT_PRINT_DEC for printing
8858 (hppa_expand_prologue, hppa_expand_epilogue): Use HOST_WIDE_INT for
8859 frame offset calculations.
8860 * pa.h (NEW_HP_ASSEMBLER): Add comment.
8861 (MAX_LEGIT_64BIT_CONST_INT, MIN_LEGIT_64BIT_CONST_INT,
8862 LEGITIMATE_64BIT_CONST_INT_P): Define.
8863 (LEGITIMATE_CONSTANT_P): Use LEGITIMATE_64BIT_CONST_INT_P. Treat
8864 any CONST_INT as legitimate during and after reload.
8865 (VAL_32_BITS_P, INT_32_BITS): Define.
8866 (LEGITIMIZE_RELOAD_ADDRESS): Handle large frame offsets.
8868 2004-01-20 Jan Hubicka <jh@suse.cz>
8870 * emit-rtl.c (verify_rtx_sharing, copy_insn_1,
8871 emit_copy_of_insn_after, emit_copy_of_insn_after): Clobbers
8872 containing hard regs are shared.
8873 (gen_hard_reg_clobber): New function.
8874 (hard_reg_clobbers): New array.
8875 * genemit.c (gen_exp): Use gen_hard_reg_clobber.
8876 (copy_rtx): Do not copy clobbers containing hard regs.
8877 * rtl.h (gen_hard_reg_clobber): Declare.
8879 2004-01-20 Jan Hubicka <jh@suse.cz>
8881 * varray.c: Include hashtab.h
8882 (varray_descriptor): New structure.
8883 (hash_descriptor, eq_descriptor, varray_descriptor,
8884 print_statistics): New static functions
8885 (varray_init, varray_grow): Update statistics
8886 (dump_varray_statistics): New function.
8887 * varray.h (dump_varray_statistics): Declare.
8888 * toplev.c (finalize): Call it.
8889 * Makefile.in (varray.o): Add dependency.
8891 2004-01-20 Jan Hubicka <jh@suse.cz>
8893 * cselib.c: Include alloc-pool.h
8894 (empty_vals, empty_elt_lists, empty_elt_loc_lists): Kill.
8895 (elt_loc_list_pool, elt_list_pool, cselib_val_pool): Declare.
8896 (new_elt_list, new_elt_loc_list, unchain_one_elt_list,
8897 unchain_one_elt_loc_list_pool, unchain_one_value,
8898 new_cselib_val): Simplify using allocpool.
8899 (cselib_init): Initialize allocpools.
8900 (cselib_finish): Finish allocpools.
8901 * Makefile.in (cselib.o): Depend on alloc-pool.h
8903 2004-01-20 Richard Sandiford <rsandifo@redhat.com>
8905 * config/mips/mips.c (mips_load_call_address): Make the call insn
8906 use $gp if it could be calling a lazy binding stub.
8908 2004-01-20 Kazu Hirata <kazu@cs.umass.edu>
8910 * config/s390/s390.c (TARGET_PROMOTE_FUNCTION_ARGS): Define.
8911 (TARGET_PROMOTE_FUNCTION_RETURN): Likewise.
8912 (TARGET_STRUCT_VALUE_RTX): Likewise.
8913 * config/s390/s390.h (PROMOTE_FUNCTION_ARGS): Remove.
8914 (PROMOTE_FUNCTION_RETURN): Remove.
8915 (STRUCT_VALUE): Remove.
8917 2004-01-20 Denis Chertykov <denisc@overta.ru>
8920 * config/avr/avr.h (BASE_REG_CLASS): Don't permit to use X
8921 register as pointer after reload.
8923 2004-01-20 Zdenek Dvorak <rakdver@atrey.karlin.mff.cuni.cz>
8925 PR optimization/12440
8926 * loop.c: Include ggc.h.
8927 (loop_optimize): Run garbage collector between optimization of loops.
8928 * Makefile.in (loop.o): Add GGC_H dependency.
8930 2004-01-20 Hartmut Penner <hpenner@de.ibm.com>
8932 * gcc/config/rs6000/rs6000.c (function_arg) Handle
8933 vector register special in function without prototype.
8934 (function_arg_advance): Vector parameters get always
8935 GPRs allocated for the linux64 target.
8937 2004-01-20 Kazuhiro Inaoka <inaoka.kazuhiro@renesas.com>
8939 * config/m32r/m32r.h (TARGET_M32R2). Test for TARGET_M32R2_MASK
8940 not TARGET_M32RX_MASK.
8942 2004-01-20 Eric Botcazou <ebotcazou@libertysurf.fr>
8945 * config/sparc/sparc.c (function_arg): Reorder the cases.
8947 2004-01-19 Per Bothner <per@bothner.com>
8949 Move cpp_reader's line_maps field to a shared global.
8950 * cpphash.h (cpp_reader): Rename line_maps field to line_table
8951 and change the type to a pointer rather than a struct.
8952 * cppinit.c (cpp_push_main_field): Adjust accordingly.
8953 * cpplib.c (do_include_common, _cpp_do_file_change, cpp_get_callbacks):
8955 * cppfiles.c (validate_pch): Likewise.
8956 * cppmacro.c (_cpp_warn_if_unused_macro, _cpp_builtin_macro_text):
8958 * cpperror.c (print_location): Likewise.
8959 * cpplib.h (cpp_create_reader): New line_maps pointer parameter.
8960 * cppinit.c (cpp_create_reader): Handle new parameter.
8961 (cpp_destroy): Don't free line_maps - that's no longer our job.
8962 * input.h (line_table): New variable.
8963 * toplev.c (line_table): Declare variable.
8964 (general_init): Initialize line_table.
8965 * c-opts.c (c_common_init_options): Pass line_table to
8967 * fix-header.c (read_scan_file): New local variable line_table.
8968 Initialize, and pass it to cpp_create_reader.
8969 * Makefile.in (LIBS, LIBDEPS): Add libcpp.a.
8970 (C_AND_OBJC_OBJS, fix-header): Remove redundant libcpp.a.
8972 2004-01-19 Per Bothner <per@bothner.com>
8974 Implement a cache for linemap_lookup.
8975 * line-map.h (struct_line_maps): Add cache field.
8976 * line-map.c (linemap_init): Zero cache field.
8977 (linemap_add): Set cache field to offset of newly allocated map.
8978 (linemap_lookup): Use and set cache field.
8980 2004-01-20 Kaz Kojima <kkojima@gcc.gnu.org>
8982 PR optimization/13567
8983 * cse.c (cse_basic_block): Call cse_insn with a non-null
8984 libcall_insn for the last SET insn of a no-confilict block.
8986 2004-01-20 Kelley Cook <kcook@gcc.gnu.org>
8988 * Makefile.in (target_noncanonical, program_transform_name): Use
8989 immediate define instead of deferred.
8990 (GCC_INSTALL_NAME, GCC_TARGET_INSTALL_NAME, CPP_INSTALL_NAME,
8991 PROTOIZE_INSTALL_NAME, UNPROTOIZE_INSTALL_NAME, GCOV_INSTALL_NAME,
8992 GCCBUG_INSTALL_NAME): Define via a immediate $(shell) instead of
8995 2004-01-20 Joseph S. Myers <jsm@polyomino.org.uk>
8997 * c-decl.c (c_init_decl_processing): Set pedantic_lvalues to
8998 true unconditionally.
8999 * c-typeck.c (unary_complex_lvalue, pedantic_lvalue_warning):
9001 (build_unary_op, build_modify_expr): Don't handle extended
9003 (build_component_ref, build_conditional_expr): Call non_lvalue
9004 instead of pedantic_non_lvalue.
9005 (build_c_cast): Don't condition use of non_lvalue on pedantic.
9006 * fold-const.c (fold): Don't check pedantic directly for
9007 COMPOUND_EXPR. Ensure that results for COMPOUND_EXPR are
9008 passed to pedantic_non_lvalue.
9009 * doc/extend.texi: Remove documentation of extended lvalues.
9011 2004-01-19 Roger Sayle <roger@eyesopen.com>
9013 PR optimization/5263
9014 * simplify-rtx.c (associative_constant_p): Delete.
9015 (simplify_associative_operation): Rewrite to linearize terms, and
9016 attempt to simplify new term against both left and right subterms.
9017 (simplify_binary_operation): Call swap_commutative_operands_p on
9018 op0 and op1, not trueop0 and trueop1. Move the initialization of
9019 trueop0 and trueop1 down to where first needed.
9020 (simplify_relational_operation): Likewise.
9021 * rtlanal.c (commutative_operand_precedence): Also order constant
9022 operands using avoid_constant_pool_reference.
9024 2004-01-19 Richard Henderson <rth@redhat.com>
9026 * config/alpha/alpha.c (aligned_memory_operand): Check MEM_ALIGN,
9027 don't check memory mode.
9028 (unaligned_memory_operand): Likewise.
9029 (reload_inqi, reload_inhi, reload_outqi, reload_outhi): Don't
9030 abort for op0 not MEM.
9032 * config/alpha/alpha.c (alpha_expand_mov_nobwx): If the destination
9033 is not a reg, copy to a scratch first.
9034 (aligned_loadqi, aligned_loadhi, unaligned_loadqi, unaligned_loadhi,
9035 unaligned_loadqi_le, unaligned_loadqi_be, unaligned_loadhi_le,
9036 unaligned_loadhi_be): Expect op0 in DImode; don't SUBREG.
9037 (reload_inqi, reload_inhi): Fix mode of op0.
9038 (reload_inqi_help, reload_inhi_help, reload_outqi_help,
9039 reload_outhi_help): Likewise. Use define_insn_and_split.
9041 * config/alpha/alpha.md (call peepholes): Check for REG_NORETURN
9042 as well as $29 dead.
9044 2004-01-19 Eric Botcazou <ebotcazou@libertysurf.fr>
9046 * config/sparc/sol2.h (ASM_DECLARE_OBJECT_NAME): New. Emit
9047 "tls_object" for thread-local objects.
9048 * config/sparc/sparc.c (sparc_elf_asm_named_section): Emit
9049 "#tls" for thread-local sections.
9050 * configure.ac (thread-local checks): Specify --fatal-warnings in
9051 every binutils-specific checks. For sparc*-*-*, test whether the
9052 OS is Solaris and the tools are native and act accordingly.
9053 * configure: Rebuild.
9055 2004-01-19 Jeff Law <law@redhat.com>
9057 * contrib.texi: Update Paolo Carlini's entry. New entries for
9058 Jerry Quinn and Petur Runolfsson.
9060 2004-01-19 Roger Sayle <roger@eyesopen.com>
9062 * config/i386/i386.md (*movhi_1, *movqi_1): When optimizing for
9063 size, don't use the larger zero-extending loads.
9065 2004-01-19 Richard Henderson <rth@redhat.com>
9067 * alpha.h (HARD_REGNO_MODE_OK): Disallow SImode in FP regs.
9068 * alpha.md (UNSPEC_NT_LDA): Remove.
9069 (UNSPEC_CVTLQ, cvtlq): New.
9070 (extendsidi2_1): Rename from extendsidi2_nofix; remove f/f.
9071 (extendsidi2_fix): Remove.
9072 (extendsidi2 splitter): Use cvtlq.
9073 (extendsidi2 fp peepholes): Remove.
9074 (cvtql): Use SFmode instead of SImode.
9075 (fix_trunc?fsi): Update to match.
9076 (floatsisf2_ieee, floatsisf2, floatsidf2_ieee, floatsidf2): New.
9077 (movsi): Rename from movsi_nofix, remove f alternatives.
9078 (movsi_nt_vms): Similarly.
9079 (movsi_fix, movsi_nt_vms_fix): Remove.
9081 * alpha.c (alpha_expand_prologue): Use adddi3, not nt_lda.
9083 2004-01-19 Jan Hubicka <jh@suse.cz>
9085 * cgraph.c (cgraph_remove_node): Fix removal from linked list.
9086 * cgraphunit.c (cgraph_finalize_compilation_unit): Clear next_needed
9088 (cgraph_remove_unreachable_nodes): New function
9089 (cgraph_decide_inlining_of_small_function): Fix pasto.
9090 (cgraph_decide_inlining_incrementally): Fix pasto.
9091 (cgrpah_decide_inlining): Likewise; remove unreachable nodes.
9093 2004-01-19 Steven Bosscher <stevenb@suse.de>
9095 * gengtype.c (header_file): Make it static.
9096 (write_types_process_field, write_enum_defn): Minor whitespace fixes.
9097 * gengtype.h (header_file): No longer extern.
9099 2004-01-18 Kazu Hirata <kazu@cs.umass.edu>
9101 * defaults.h (CASE_VECTOR_PC_RELATIVE): Provide the default.
9102 * expr.c (CASE_VECTOR_PC_RELATIVE): Remove.
9103 * stmt.c (CASE_VECTOR_PC_RELATIVE): Likewise.
9105 2004-01-18 Kazu Hirata <kazu@cs.umass.edu>
9107 * stmt.c (HAVE_casesi): Define it not already defined.
9108 (HAVE_tablejump): Likewise.
9109 (expand_end_case_type): Resort to the binary tree method if
9110 neither casesi or tablejump is available.
9112 2004-01-18 Daniel Jacobowitz <drow@mvista.com>
9114 * final.c (final_scan_insn): Make non-static again.
9115 * output.h (final_scan_insn): Re-add prototype.
9116 * config/arc/arc.c (arc_output_function_epilogue): Add NULL
9117 to final_scan_insn call.
9118 * config/cris/cris.c (cris_target_asm_function_epilogue): Likewise.
9119 * config/mips/mips.c (mips_output_conditional_branch): Likewise.
9120 * config/pa/pa.c (output_lbranch, output_call): Likewise.
9121 * config/sh/sh.c (print_slot): Likewise.
9122 * config/sparc/sparc.c (sparc_nonflat_function_epilogue): Likewise.
9123 (output_sibcall, sparc_flat_function_epilogue): Likewise.
9125 2004-01-18 Jan Hubicka <jh@suse.cz>
9127 * basic-block.h (try_redirect_by_replacing_jump): Declare.
9128 * cfgcleanup.c (try_optimize_cfg): Use it.
9129 * cfgrtl.c (try_redirect_by_replacing_jump): Export.
9130 (rtl_redirect_edge_and_branch, cfg_layout_redirect_edge_and_branch):
9132 (cfg_layout_merge_blocks): Use try_redirect_by_replacing_jump.
9135 2004-01-16 Geoffrey Keating <geoffk@apple.com>
9137 * cfgrtl.c (try_redirect_by_replacing_jump): Optimize tablejumps
9138 even after reload, just don't remove the actual jump tables.
9140 2004-01-18 Kazu Hirata <kazu@cs.umass.edu>
9142 * config/rs6000/rs6000.h (STRICT_ARGUMENT_NAMING): Remove.
9144 2004-01-18 Kazu Hirata <kazu@cs.umass.edu>
9146 * defaults.h (ASM_OUTPUT_ADDR_VEC_ELT): Fix the computation of
9147 the size of a pointer in bytes.
9149 2004-01-18 Roger Sayle <roger@eyesopen.com>
9151 * builtins.c (expand_builtin_expect_jump): Fix thinko of reusing
9152 live "next" variable, which could lead to an infinite loop.
9154 2004-01-18 Andrew Pinski <pinskia@physics.uc.edu>
9156 * config/rs6000/altivec.h: Wrap C++ functions in extern "C++"
9159 * config/rs6000/rs6000.c (rs6000_special_round_type_align):
9160 Check for NULL in the chain and remove repeated code.
9162 2004-01-18 Jan Hubicka <jh@suse.cz>
9164 * coverage.c (checksum_string): Rename to ...
9165 (coverage_checksum_string): ... this one, Use crc32_string; recognize
9166 names containing random number and zero the number out in order to get
9169 2004-01-18 Richard Sandiford <rsandifo@redhat.com>
9171 * config/mips/mips.c (mips_got_alias_set): Mark for PCH.
9173 2004-01-18 Joseph S. Myers <jsm@polyomino.org.uk>
9175 * doc/c-tree.texi, doc/cpp.texi, doc/extend.texi,
9176 doc/frontends.texi, doc/gcov.texi, doc/gty.texi, doc/install.texi,
9177 doc/invoke.texi, doc/libgcc.texi, doc/md.texi, doc/rtl.texi,
9178 doc/sourcebuild.texi, doc/standards.texi, doc/tm.texi,
9179 doc/trouble.texi: Remove trailing whitespace.
9181 2004-01-18 Richard Sandiford <rsandifo@redhat.com>
9184 * config/mips/mips.c: Include cfglayout.h.
9185 (TARGET_ASM_OUTPUT_MI_THUNK, TARGET_ASM_CAN_OUTPUT_MI_THUNK): Define.
9186 (mips_unspec_offset_high): Add temporary register argument.
9187 (mips_load_call_address): New function, split out from...
9188 (mips_expand_call): ...here.
9189 (mips_output_cplocal): New function.
9190 (mips_output_function_prologue, mips_output_function_epilogue): Use it.
9191 (mips_emit_loadgp): New function, split out from...
9192 (mips_expand_prologue): ...here.
9193 (mips_output_mi_thunk): New function.
9195 2004-01-17 Bernardo Innocenti <bernie@develer.com>
9197 * longlong.h (mc68020, __mc68030__, mc68030, __mc68040__, mc68040,
9198 mcpu32): Remove redundant checks for implied target predefines.
9200 2004-1-17 Andrew Pinski <pinskia@physics.uc.edu>
9202 * config/rs6000/rs6000.c (rs6000_special_round_type_align):
9203 Return type is unsigned int not int.
9204 * config/rs6000/rs6000-protos.h (rs6000_special_round_type_align):
9207 2004-01-18 Joseph S. Myers <jsm@polyomino.org.uk>
9209 * doc/contrib.texi, doc/cppenv.texi, doc/extend.texi,
9210 doc/install.texi, doc/invoke.texi, doc/tm.texi: Consistently use
9211 "GNU/Linux" and "Microsoft Windows" terminology.
9213 2004-01-18 Joseph S. Myers <jsm@polyomino.org.uk>
9215 * doc/c-tree.texi, doc/compat.texi, doc/cpp.texi,
9216 doc/cppopts.texi, doc/extend.texi, doc/install.texi,
9217 doc/interface.texi, doc/invoke.texi, doc/libgcc.texi, doc/md.texi,
9218 doc/objc.texi, doc/rtl.texi, doc/tm.texi, doc/trouble.texi: Use
9219 @smallexample instead of @example.
9221 2004-01-17 Ziemowit Laski <zlaski@apple.com>
9223 * objc/objc-act.c (build_objc_method_call): Use target
9224 hooks instead of macros to determine if ..._stret
9225 dispatchers should be used (NeXT runtime only).
9227 2004-01-17 Roger Sayle <roger@eyesopen.com>
9229 * builtins.c (expand_builtin_expect_jump): Fix mistake in my
9230 last patch. Use XEXP (x, 0) to get a LABEL_REF's CODE_LABEL.
9232 2004-01-17 Daniel Jacobowitz <drow@mvista.com>
9234 * rtl.h (emit_insn_before_sameloc, emit_jump_insn_before_sameloc)
9235 (emit_call_insn_before_sameloc, emit_insn_after_sameloc)
9236 (emit_jump_insn_after_sameloc, emit_call_insn_after_sameloc): New
9238 * reload1.c (emit_reload_insns): Use them.
9239 * emit-rtl.c (emit_insn_before_sameloc, emit_insn_after_sameloc)
9240 (emit_jump_insn_after_sameloc, emit_call_insn_after_sameloc): Check
9243 2004-01-17 Daniel Jacobowitz <drow@mvista.com>
9245 * final.c (SEEN_BB, SEEN_NOTE, SEEN_EMITTED): Define.
9246 (final_scan_insn): Update to take an additional SEEN argument. Emit
9247 a line note after the prologue. Make static.
9248 (line_note_exists): Remove.
9249 (final): Don't initialize line_note_exists. Update call to
9251 * output.h (final_scan_insn): Remove prologue.
9252 * function.c (set_insn_locators): Update comment.
9253 (thread_prologue_and_epilogue_insns): Add a comment.
9255 2004-01-17 Andrew Pinski <pinskia@physics.uc.edu>
9258 * config/rs6000/rs6000-protos.h (rs6000_special_round_type_align):
9260 * config/rs6000/rs6000.c (rs6000_special_round_type_align):
9262 * config/rs6000/linux64.h (ROUND_TYPE_ALIGN): Use it.
9263 * config/rs6000/aix.h (ROUND_TYPE_ALIGN): Likewise.
9264 * config/rs6000/darwin.h (ROUND_TYPE_ALIGN): Likewise.
9266 2004-01-17 Jan Hubicka <jh@suse.cz>
9268 * toplev.c (rest_of_handle_reorder_blocks): Fix pasto in previous
9271 * toplev.c (HAVE_conditional_execution): Provide default.
9272 (rest_of_handle_reorder_blocks): For conditional_execution target
9273 update liveness once after all transformations
9274 (rest_of_compilation): Do crossjumping before ce3.
9276 2004-01-17 Geoffrey Keating <geoffk@apple.com>
9278 * alias.c (new_alias_set): Mark last_alias_set for PCH.
9279 (get_varargs_alias_set): Rename 'set' to 'varargs_set' and mark it
9281 (get_frame_alias_set): Likewise, except rename it to 'frame_set'.
9282 * config/rs6000/rs6000.c (rs6000_sr_alias_set): Mark for PCH.
9283 (get_TOC_alias_set): Mark 'set' for PCH.
9285 2004-01-16 Geoffrey Keating <geoffk@apple.com>
9287 * cfgrtl.c (try_redirect_by_replacing_jump): Optimize tablejumps
9288 even after reload, just don't remove the actual jump tables.
9290 2004-01-17 J. Brobecker <brobecker@gnat.com>
9292 * dwarf2out.c (is_subrange_type): Renamed from is_ada_subrange_type().
9293 Remove checks for is_ada() and TREE_UNSIGNED.
9294 (subrange_type_die): Emit a byte_size attribute if the subrange
9295 type size is different from the base type size.
9296 (modified_type_die): Replace call to is_ada_subrange_type() by
9297 call to is_subrange_type().
9299 2004-01-16 Andrew Pinski <pinskia@physics.uc.edu>
9301 * config/sh/sh.c: Include ggc.h.
9303 2004-01-16 Geoffrey Keating <geoffk@apple.com>
9305 * Makefile.in (MD5_H): New.
9306 (fold-const.o): Depend on md5.h.
9307 (dwarf2out.o): Likewise.
9308 (cppfiles.o): Likewise.
9309 * cppfiles.c: Include md5.h.
9310 (should_stack_file): Check against list read from PCH file.
9311 (struct pchf_data): New.
9312 (pchf): New variable.
9313 (struct pchf_adder_info): New.
9315 (pchf_save_compare): New.
9316 (_cpp_save_file_entries): New.
9317 (_cpp_read_file_entries): New.
9318 (struct pchf_compare_data): New.
9319 (pchf_compare): New.
9320 (check_file_against_entries): New.
9321 * cpphash.h (_cpp_save_file_entries): Prototype.
9322 (_cpp_read_file_entries): Prototype.
9323 * cpppch.c (cpp_write_pch_state): Write the list of headers.
9324 (cpp_read_state): Read the list of headers.
9326 2004-01-17 Jan Hubicka <jh@suse.cz>
9328 * c-common.c (c_estimate_num_insns_1): Handle builtin_constant_p and
9329 builtin_expect specially.
9330 * params.def (PARAM_MAX_INLINE_INSNS_AUTO): Set to 100.
9331 (PARAM_LARGE_FUNCTION_INSNS): Set to 3000.
9332 * invoke.texi (max-inline-insns-single): Set to 100.
9333 (large-function-insns): Set to 3000.
9335 2004-01-16 Eric Christopher <echristo@redhat.com>
9336 Chandrakala Chavva <cchavva@redhat.com>
9338 * cppcharset.c (one_iso88591_to_utf8): New function.
9339 (convert_iso88591_utf8): Ditto. Use.
9340 (conversion_tab): Use.
9341 (_cpp_input_to_utf8): New function.
9342 (_cpp_init_iconv_buffer): Ditto.
9343 (_cpp_close_iconv_buffer): Ditto.
9344 * cpphash.h: Prototype new functions.
9345 (cpp_buffer): Add input_cset_desc.
9346 * cppinit.c: Add input_charset default.
9347 * cpplib.c (cpp_push_buffer): Support init and
9349 * cpplib.h (cpp_options): Add input_charset.
9351 2004-01-16 Kazu Hirata <kazu@cs.umass.edu>
9353 * system.h (ASM_OUTPUT_SECTION_NAME): Poison.
9354 * config/alpha/unicosmk.h: Remove a commented-out definition
9355 of ASM_OUTPUT_SECTION_NAME.
9356 * config/stormy16/stormy16.h: Likewise.
9358 2004-01-16 Rainer Orth <ro@TechFak.Uni-Bielefeld.DE>
9360 * fixinc/inclhack.def (alpha___extern_prefix): Renamed to ...
9361 (alpha___extern_prefix_sys_stat): ... this.
9362 Apply to <sys/mount.h>, too.
9363 Tweak to match more variations.
9364 * fixinc/tests/base/sys/stat.h: Adapt for new hackname.
9366 * fixinc/inclhack.def (alpha___extern_prefix,
9367 alpha___extern_prefix_standards): New hacks to obey
9368 __PRAGMA_EXTERN_PREFIX.
9369 * fixinc/tests/base/testing.h [ALPHA___EXTERN_PREFIX_CHECK]: New
9371 * fixinc/tests/base/standards.h: Likewise.
9373 * fixincl/inclhack.def (alpha_pthread): Tweak to match more
9376 * fixinc/tests/base/pthread.h: Handle it.
9378 * fixincl/inclhack.def (bad_lval): Sort file list.
9379 Add many missing files up to Tru64 UNIX V5.1B.
9380 * gcc/fixinc/tests/base/libgen.h: Renamed to ...
9381 * gcc/fixinc/tests/base/dirent.h: ... this to match new file list
9384 * fixinc/fixincl.x: Regenerate.
9386 2004-01-16 Mark Mitchell <mark@codesourcery.com>
9388 * version.c (version_string): Change to 3.5.0.
9389 * doc/include/gcc-common.texi (version-GCC): Likewise.
9391 2004-01-16 Jan Hubicka <jh@suse.cz>
9393 * i386.md (load_tp_di): Fix pasto.
9396 * i386.c (ix86_compute_frame_layout): Fix for alloca on leaf function.
9398 * c-pretty-print.c (pp_c_type_cast, pp_c_abstract_declarator,
9399 pp_c_character_constant, pp_c_floating_constant,
9400 pp_c_additive_expression, pp_c_shift_expression,
9401 pp_c_equality_expression, pp_c_and_expression,
9402 pp_c_exclusive_or_expression, pp_c_inclusive_or_expression,
9403 pp_c_logical_and_expression): Remove inline modifier.
9404 * dwarf2out.c (get_AT): Likewise.
9405 * et-forest.c (et_splay): Likewise.
9406 * ra.h (ra_alloc, ra_calloc): Likewise
9408 2004-01-16 Kazu Hirata <kazu@cs.umass.edu>
9410 * config/frv/frv-protos.h: Fix comment formatting.
9411 * config/frv/frv.c: Likewise.
9412 * config/frv/frv.h: Likewise.
9413 * config/frv/frv.md: Likewise.
9414 * config/frv/frvbegin.c: Likewise.
9415 * config/frv/frvend.c: Likewise.
9417 2004-01-16 Kazu Hirata <kazu@cs.umass.edu>
9419 * system.h (LINKER_DOES_NOT_WORK_WITH_DWARF2): Poison.
9420 * doc/tm.texi (PREFERRED_DEBUGGING_TYPE): Don't mention
9421 LINKER_DOES_NOT_WORK_WITH_DWARF2.
9422 (LINKER_DOES_NOT_WORK_WITH_DWARF2): Remove.
9424 2004-01-16 J"orn Rennecke <joern.rennecke@superh.com>
9427 * postreload.c (reload_cse_simplify_operands): Don't remove
9428 implicit extension from LOAD_EXTEND_OP.
9430 2004-01-16 Jan Hubicka <jh@suse.cz>
9433 * cfgcleanup.c (try_optimize_cfg): Suppress tablejump removal
9435 * cfgrtl.c (rtl_can_merge_blocks, cfglayout_can_merge_blocks,
9436 rtl_try_redirect_by_replacing_branch): Likewise.
9438 2004-01-15 Geoffrey Keating <geoffk@apple.com>
9441 * alias.c (struct alias_set_entry): Mark for GC.
9442 (alias_sets): Make static, mark for GC.
9443 (record_alias_subset): Use GC to allocate alias structures.
9444 * varray.c (element): Make generic varrays GCed.
9447 * c-typeck.c (constructor_asmspec): Delete.
9448 (struct initializer_stack): Delete field 'asmspec'.
9449 (start_init): Delete saving of asmspec.
9450 (finish_init): Don't update constructor_asmspec.
9451 * dwarf2out.c (rtl_for_decl_location): Duplicate string from tree.
9452 * stmt.c (expand_asm): Duplicate strings from tree.
9453 (expand_asm_operands): Likewise.
9454 * tree.c (tree_size): Update computation of size of STRING_CST.
9455 (make_node): Don't make STRING_CST nodes.
9456 (build_string): Allocate string with tree node.
9457 * tree.def (STRING_CST): Update comment.
9458 * tree.h (TREE_STRING_POINTER): Adjust for change to STRING_CST.
9459 (tree_string): Place contents of string in tree node.
9460 * config/sh/sh.c (sh_handle_sp_switch_attribute): Duplicate string
9463 * config/rs6000/rs6000.c (rs6000_va_arg): No need to special-case
9466 2004-01-15 Kazu Hirata <kazu@cs.umass.edu>
9468 * c-common.h: Fix comment formatting.
9469 * c-cppbuiltin.c: Likewise.
9470 * c-pragma.c: Likewise.
9471 * calls.c: Likewise.
9472 * collect2.c: Likewise.
9473 * cppcharset.c: Likewise.
9474 * cpptrad.c: Likewise.
9475 * dbxout.c: Likewise.
9476 * defaults.h: Likewise.
9477 * dwarf2out.c: Likewise.
9478 * fold-const.c: Likewise.
9479 * genautomata.c: Likewise.
9480 * genconditions.c: Likewise.
9481 * genflags.c: Likewise.
9482 * gengtype.c: Likewise.
9483 * integrate.c: Likewise.
9485 * predict.c: Likewise.
9486 * sdbout.c: Likewise.
9488 2004-01-15 Zack Weinberg <zack@codesourcery.com>
9490 * config/ia64/ia64.md (*movti_internal): C output template
9491 extracted to ia64.c.
9492 (*movti_internal_reg): Delete.
9493 (reload_inti, reload_outti): Use the correct mode on operand 2
9494 in the first place, don't fix it up in the output template.
9495 (movtf, reload_ointf, reload_outtf): New expanders.
9496 (*movtf_internal): New define_insn_and_split.
9497 * config/ia64/ia64.c (ia64_split_timode): Rename to ia64_split_tmode;
9498 make static; do not hand TFmode CONST_DOUBLEs to split_double.
9499 (ia64_split_tmode_move): New function, body mostly pulled
9500 from ia64.md:*movti_internal.
9501 (ia64_function_arg_words): New function, extracted common
9502 logic from ia64_function_arg et seq.
9503 (ia64_function_arg_offset): Likewise. Handle correctly the
9504 case of a scalar quantity 16 bytes wide with only 8-byte alignment.
9505 (ia64_function_arg, ia64_function_arg_partial_nregs)
9506 (ia64_function_arg_advance): Use ia64_function_arg_words and
9507 ia64_function_arg_offset.
9508 (ia64_function_value): TCmode does not go in float regs.
9509 (ia64_secondary_reload_class): Also handle TFmode.
9510 * config/ia64/ia64-protos.h: Remove prototype for
9511 ia64_split_timode; add prototype for ia64_split_tmode_move.
9513 2004-01-15 Kelley Cook <kcook@gcc.gnu.org>
9515 * Makefile.in (MAINT): Make it an immediate assignment.
9517 2004-01-15 Kazu Hirata <kazu@cs.umass.edu>
9519 * config/m32r/m32r.md: Remove useless calls to gen_lowpart.
9521 2004-01-15 Kazu Hirata <kazu@cs.umass.edu>
9523 * config/h8300/coff.h: Replace Hitachi with Renesas.
9524 * config/h8300/elf.h: Likewise.
9525 * config/h8300/h8300-protos.h: Likewise.
9526 * config/h8300/h8300.c: Likewise.
9527 * config/h8300/h8300.h: Likewise.
9528 * config/h8300/h8300.md: Likewise.
9529 * config/h8300/lib1funcs.asm: Likewise.
9531 2004-01-15 Andrew Pinski <apinski@apple.com>
9533 * config/rs6000/rs6000.c (uses_TOC): Wrap #if TARGET_ELF
9536 2004-01-15 Kazu Hirata <kazu@cs.umass.edu>
9538 * config/h8300/h8300.c (h8300_return_in_memory): New.
9539 (TARGET_STRUCT_VALUE_RTX): Likewise.
9540 (TARGET_RETURN_IN_MEMORY): Likewise.
9541 * config/h8300/h8300.h (STRUCT_VALUE): Remove.
9542 (RETURN_IN_MEMORY): Likewise.
9544 2004-01-15 Richard Earnshaw <rearnsha@arm.com>
9546 PR optimization/13375
9547 * gcse.c (handle_avail_expr): Just return if the source is not a
9550 2004-01-15 Richard Earnshaw <rearnsha@arm.com>
9551 Daniel Jacobowitz <drow@mvista.com>
9553 * arm/lib1funcs.asm (ARM_FUNC_START): Correct interworking case.
9555 (ARM_FUNC_ALIAS): New macro.
9556 * arm/ieee754-df.S (gedf2, ledf2, nedf2, eqdf2): Use it.
9557 * arm/ieee754-sf.S (gesf2, lesf2, nesf2, eqsf2): Use it.
9559 2004-01-15 John David Anglin <dave.anglin@nrc-cnrc.gc.ca>
9561 PR optimization/12372
9562 * calls.c (expand_call): Add call_fusage data for stack arguments in
9565 2004-01-15 Alan Modra <amodra@bigpond.net.au>
9567 * config/rs6000/rs6000.c (uses_TOC): Correct comment. Make static.
9568 (rs6000_elf_declare_function_name): Formatting.
9569 * config/rs6000/rs6000-protos.h (uses_TOC): Remove declaration.
9571 2004-01-15 Jan Hubicka <jh@suse.cz>
9574 * sched-deps.c (sched_analyze_1, sched_analyze_2): Fix thinko in
9577 2004-01-15 Richard Henderson <rth@redhat.com>
9579 * config/alpha/alpha.h (REG_ALLOC_ORDER): Reorder fp regs after
9580 integer regs of the same call-savedness.
9582 2004-01-15 Andreas Schwab <schwab@suse.de>
9585 * config/m68k/m68k.c (output_move_const_into_data_reg): Clear cc
9586 status for NOTB/NOTW/NEGW methods.
9588 2004-01-15 Kazu Hirata <kazu@cs.umass.edu>
9590 * doc/invoke.texi: Update dump file names. Fix a typo.
9592 2004-01-15 Kazu Hirata <kazu@cs.umass.edu>
9594 * builtins.c (expand_builtin_va_end): Don't use
9595 EXPAND_BUILTIN_VA_END.
9596 * system.h (EXPAND_BUILTIN_VA_END): Poison.
9597 * config/d30v/d30v.h: Remove a commented-out definition of
9598 EXPAND_BUILTIN_VA_END.
9599 * config/stormy16/stormy16.h: Likewise.
9601 2004-01-15 Kazu Hirata <kazu@cs.umass.edu>
9603 * system.h (STRUCT_VALUE_INCOMING_REGNUM): Poison.
9604 * targhooks.c (default_struct_value_rtx): Don't use
9605 STRUCT_VALUE_INCOMING_REGNUM.
9607 2004-01-15 Kelley Cook <kcook@gcc.gnu.org>
9610 * configure.in: Revamp enable-generated-files-in-srcdir rule to define
9611 GENINSRC and not parsedir. Define srcextra as a langhook.
9612 * configure: Regenerate.
9613 * Makefile.in: Suppress default .l.c rule. Don't substitute
9614 parsedir and delete all references throughout. Conditionally define
9615 rule for srcextra dependent on GENINSRC.
9616 (stmp-docobjdir): Delete.
9617 (c-parse.o, gengtype-lex.o, gengtype-yacc.o): Use implicit build rule.
9618 (srcextra): Copy c-parse.y, c-parse.c, gengtype-lex.c, gengtype-yacc.c,
9619 and gengtype-yacc.h back to source directory.
9620 (maintainer-clean): Delete all parse files in source directory.
9621 (distclean): Delete generated files.
9623 * objc/Make-lang.in (objc-parse.o): Use implicit build rule.
9624 (objc-parse.c, objc-parse.y): Don't use parsedir.
9625 (objc.srcextra): Copy objc-parse.y and objc-parse.c back to source
9626 directory if requested.
9627 (po-generated): Don't use parsedir.
9628 (objc.maintainer-clean): Delete above files from source directory.
9630 2004-01-14 Kazu Hirata <kazu@cs.umass.edu>
9632 * doc/tm.texi (FUNCTION_VALUE): Fix a typo.
9634 2004-01-14 Kazu Hirata <kazu@cs.umass.edu>
9636 * doc/tm.texi: Replace RETURN_IN_MEMORY with
9637 TARGET_RETURN_IN_MEMORY.
9639 2004-01-15 Jan Hubicka <jh@suse.cz>
9641 * builtins.c (std_expand_builtin_va_arg): Align operand when needed.
9642 * i386.c (init_cumulative_args): Set warn_sse; fix handling of variadic
9643 functions accepting SSE arguments
9644 (function_arg): Warn only when asked to warn.
9645 * i386.h (ix86_args): Add warn_sse/warn_mmx fiels.
9647 2004-01-14 Joseph S. Myers <jsm@polyomino.org.uk>
9649 * c-parse.in (stmts_and_decls): Make label at end of compound
9650 statement a hard error.
9652 2004-01-14 Jan Hubicka <jh@suse.cz>
9654 * cgraph.c (create_edge): Use local.redefined_extern_inline.
9655 * cgraph.h (cgraph_local_info): Sort fields by size; add
9656 redefined_extern_inline
9657 (cgraph_global_info): Sort fields by size.
9658 (cgraph_node): Likewise.
9659 * cgraphunit.c (cgraph_finalize_function): Se
9660 local.redefined_extern_inline on redefinition.
9661 (cgraph_analyze_function): Use it; fix formating.
9663 2004-01-14 Jan Hubicka <jh@suse.cz>
9666 * sched-deps.c (trye_dependency_cache, anti_dependency_cache,
9667 outptu_dependency_cache, forward_dependency_cahe): Trun to vectors of
9669 (cache_size): New variable
9670 (add_dependence): Update use; canonize early memory locations
9671 (sched_analyze_1): Likewise.
9672 (sched_analyze_2): Likewise.
9673 (init_dependency_caches): Initialize bitmaps.
9674 (free_dependency_caches): Free bitmaps
9676 2004-01-14 Kazu Hirata <kazu@cs.umass.edu>
9678 * calls.c: Replace STRICT_ARGUMENT_NAMING in comments with
9679 targetm.calls.strict_argument_naming().
9680 * target.h: Likewise.
9682 2004-01-14 Richard Henderson <rth@redhat.com>
9685 * dwarf2out.c (dwarf2out_stack_adjust): Skip prologue and epilogue
9688 2004-01-14 Richard Henderson <rth@redhat.com>
9691 * except.c (struct eh_region): Add u.fixup.resolved.
9692 (resolve_one_fixup_region): Split out from ...
9693 (resolve_fixup_regions): ... here.
9695 2004-01-14 Kazu Hirata <kazu@cs.umass.edu>
9697 * config/mn10300/mn10300.h (STRUCT_VALUE): Change to 0.
9699 2004-01-14 Kazu Hirata <kazu@cs.umass.edu>
9701 * config/alpha/alpha.h (STRUCT_VALUE): Remove.
9702 * config/alpha/vms.h (STRUCT_VALUE_REGNUM): Remove #undef.
9703 (STRUCT_VALUE): Remove.
9705 2004-01-14 Steven Bosscher <stevenb@suse.de>
9707 * system.h: Poison PROMOTED_MODE
9708 * integrate.c (expand_inline_function): Don't mention the
9710 * loop.c (update_giv_derive): Same.
9711 * tree.h (DECL_RTL): Same.
9713 2004-01-14 J"orn Rennecke <joern.rennecke@superh.com>
9716 * sh.c (gen_block_redirect): Add special handling of RETURN.
9717 (gen_far_branch) Don't call gen_stuff_delay_slot if there is no
9718 far branch target (i.e. it's a return).
9720 2004-01-14 Kazu Hirata <kazu@cs.umass.edu>
9722 * regrename.c (find_oldest_value_reg): Fix a warning.
9724 2004-01-14 Richard Earnshaw <rearnsha@arm.com>
9727 * config.gcc (arm*-*-linux*): Don't include unknown-elf.h in tm_file.
9728 Move linux-gas.h and linux-elf.h before aout.h.
9729 * arm/arm.h (INITIALIZE_TRAMPOLINE): Only define if not already.
9730 * arm/linux-elf.h (SUBTARGET_CPU_DEFAULT): Define.
9732 2004-01-14 Kazu Hirata <kazu@cs.umass.edu>
9734 * config/m32r/m32r.md: Use GEN_INT instead of gen_rtx
9735 (CONST_INT, VOIDmode, ...).
9737 2004-01-14 Richard Earnshaw <rearnsha@arm.com>
9739 * regrename.c (find_oldest_value_reg): If the replacement uses
9740 multiple hard registers, check that all of them are in CLASS.
9742 2004-01-14 Jan Hubicka <jh@suse.cz>
9744 * alias.c (get_alias_set): Initialize alias set to 0 when subset is
9747 2004-01-14 Kelley Cook <kcook@gcc.gnu.org>
9749 * Makefile.in: Define MAINT from --enable-maintainer-mode.
9751 2004-01-14 Hartmut Penner <hpenner@de.ibm.com>
9753 * gcc/config/rs6000/rs6000.c (rs6000_stack_info)
9754 Calculate always vrsave_mask if TARGET_ALTIVEC.
9755 (rs6000_emit_prologue): Emit code for vrsave
9756 only if TARGET_ALTIVEC_VRSAVE.
9757 (rs6000_emit_epilogue): Likewise.
9759 2004-01-14 Eric Botcazou <ebotcazou@libertysurf.fr>
9761 * config/sparc/sparc.md (tie_add32): Fix pasto.
9762 (tie_add64): Likewise.
9764 2004-01-14 Zdenek Dvorak <rakdver@atrey.karlin.mff.cuni.cz>
9766 * config/i386/i386.md (*addqi_1_slp): Do not access operands[2].
9768 2004-01-13 Kazu Hirata <kazu@cs.umass.edu>
9770 * config/iq2000/iq2000-protos.h: Fix comment formatting.
9771 * config/iq2000/iq2000.c: Likewise.
9772 * config/iq2000/iq2000.md: Likewise.
9774 2004-01-14 J. Brobecker <brobecker@gnat.com>
9776 * dwarf2out.c (is_ada_subrange_type): No longer check the TYPE_NAME.
9777 (subrange_type_die): Add handle for nameless subrange types.
9779 2004-01-13 Kazu Hirata <kazu@cs.umass.edu>
9781 * config/h8300/h8300-protos.h: Replace do_movsi with
9783 * config/h8300/h8300.c (do_movsi): Change to
9785 * config/h8300/h8300.md (movsi): Replace do_movsi with
9789 2004-01-13 Kazu Hirata <kazu@cs.umass.edu>
9791 * config/h8300/h8300.c (dosize): Change to
9792 h8300_emit_stack_adjustment. Update callers.
9794 2004-01-13 Kazu Hirata <kazu@cs.umass.edu>
9796 * config/h8300/h8300.md (movstrictqi): Add an alternative with
9797 the source being post_inc. Tighten the predicate for the
9798 destination to register_operand.
9799 (movstricthi): Likewise.
9801 2004-01-13 Kazu Hirata <kazu@cs.umass.edu>
9803 * system.h (SHARED_BSS_SECTION_ASM_OP): Poison.
9804 * varasm.c (bss_section): Don't use SHARED_BSS_SECTION_ASM_OP.
9805 * doc/tm.texi (SHARED_BSS_SECTION_ASM_OP): Remove.
9807 2004-01-14 Jan Hubicka <jh@suse.cz>
9809 Partial fix PR c++/12850
9810 * cgraphunit.c (cgraph_finalize_function): Always ggc_collect when
9813 2004-01-13 Bernardo Innocenti <bernie@develer.com>
9815 * config/m68k/netbsd-elf.h (REGISTER_NAMES): Add missing "argptr"
9818 2004-01-13 Devang Patel <dpatel@apple.com
9821 * dbxout.c (dbxout_symbol_name): Emit mangled names for
9822 NAMESPACE_DECL memebers.
9824 2004-01-13 Andrew Pinski <pinskia@physics.uc.edu>
9827 * c-common.c (finish_fname_decls): Use the chain only if the
9828 tree is an expr_stmt.
9830 2004-01-13 Vladimir Makarov <vmakarov@redhat.com>
9832 * rtl.def: Add comment about new option in automata_option.
9834 * genautomata.c (PROGRESS_OPTION): New macro.
9835 (progress_flag): New global variable.
9836 (gen_automata_option): Process `progress'.
9837 (transform_insn_regexps, check_unit_distributions_to_automata,
9838 make_automaton, NDFA_to_DFA, build_automaton, create_automata,
9839 expand_automata, write_automata): Print about the progress only if
9840 progress_flag. Remove fflush.
9841 (initiate_automaton_gen): Process command line flag `-progress'.
9843 * doc/md.texi: Describe the new option.
9845 2004-01-13 Zdenek Dvorak <rakdver@atrey.karlin.mff.cuni.cz>
9847 * cfg.c (dump_bb): Dump entry edges.
9849 2004-01-13 Richard Earnshaw <rearnsha@arm.com>
9851 * arm.c (thumb_legitimate_address_p): Only allow constant pool
9852 references from SImode.
9853 * arm.md (thumb_movhi_insn): Don't allow minipool references.
9855 2004-01-13 Kazu Hirata <kazu@cs.umass.edu>
9857 * system.h (TEXT_SECTION): Poison.
9858 * varasm.c (text_section): Don't use TEXT_SECTION.
9859 * config/sh/sh.c (sh_file_start): Fix a comment typo.
9860 * doc/tm.texi (TEXT_SECTION): Remove.
9862 2004-01-13 Ben Elliston <bje@wasabisystems.com>
9864 * doc/rtl.texi (Vector Operations): Remove defunct vec_const item.
9866 2004-01-12 James E Wilson <wilson@specifixinc.com>
9868 * unwind-libunwind.c: Delete.
9870 2004-01-12 Zack Weinberg <zack@codesourcery.com>
9873 * c-decl.c (diagnose_mismatched_decls): Whenever newtype or
9874 oldtype is set, set *newtypep or *oldtypep too. Do not set
9875 them at the very end.
9876 (validate_proto_after_old_defn): Restructure for comprehensibility;
9877 make error messages clearer.
9879 2004-01-12 Zack Weinberg <zack@codesourcery.com>
9881 * varray.h (VARRAY_POP): Add checking variant, aborts on underflow.
9882 (VARRAY_TOP): Use VARRAY_CHECK so the access is bounds-checked.
9883 * varray.c: No need to prototype error.
9884 (varray_check_failed): Wrap long string onto two lines.
9885 (varray_underflow): New function.
9887 2004-01-13 Steven Bosscher <stevenb@suse.de>
9890 * function.h (struct function): Kill `name' field.
9891 (current_function_name): Make it an extern function.
9892 * function.c (current_function_name): New function.
9893 * graph.c: Update all uses of current_function_name.
9895 * config/alpha/alpha.c, config/avr/avr.c, config/c4x/c4x.c,
9896 config/mips/mips.c, config/pdp11/pdp11.c: Likewise.
9897 * config/ip2k/ip2k.c (function_prologue): Use MAIN_NAME_P
9898 instead of a strcmp with "main".
9900 2004-01-13 Jan Hubicka <jh@suse.cz>
9902 * c-decl.c (diagnose_mismatched_decls): Fix warning calls.
9904 * cgraphunit.c (cgraph_optimize_function): Always do
9905 optimize_inline_calls when there is always_inline callee.
9906 (cgraph_decide_inlining): Fix formating.
9907 * tree-inline.c (inlinable_function_p): Do sorry for alwaysinline
9909 (expand_call_inline): Likewise.
9910 * toplev.h (sorry): Fix prototype.
9912 2004-01-12 Roger Sayle <roger@eyesopen.com>
9914 * builtins.c (expand_builtin_expect_jump): Simplify logic. Handle
9915 conditional jumps that drop through to unconditional jumps or the
9916 end of the sequence.
9918 2004-01-13 Jan Hubicka <jh@suse.cz>
9920 * alias.c (new_alias_set): Construct the alias_set varray.
9921 (init_alias_once): Don't do it here.
9923 2004-01-12 Marc Espie <espie@openbsd.org>
9925 * system.h: handle YYBYACC like YYBISON.
9927 2004-01-12 Jonathan Merriman <jonm@dualitymedia.com>
9930 * config.gcc: No longer includes conflicting header sparc/sol2.h when
9931 building on sparc64-*-openbsd*.
9933 2004-01-12 Andrew Pinski <pinskia@physics.uc.edu>
9936 * dbxout.c (dbxout_type): Protected inheritance is not
9937 private but protected.
9939 2004-01-12 Richard Sandiford <rsandifo@redhat.com>
9941 * config/mips/mips.c (mips_symbolic_constant_p): Revert last patch.
9943 2004-01-12 Kazu Hirata <kazu@cs.umass.edu>
9945 PR optimization/12508.
9946 * combine.c (try_combine): Remove a dead set in a parallel
9947 even if its destination is a subreg.
9950 2003-06-03 Kazu Hirata <kazu@cs.umass.edu>
9951 * combine.c (simplify_set): Don't move a subreg in SET_SRC to
9952 SET_DEST if WORD_REGISTER_OPERATIONS is not defined.
9954 2004-01-12 Geoffrey Keating <geoffk@apple.com>
9956 * real.c: Update copyright date.
9957 * emit-rtl.c: Likewise.
9959 * dwarf2out.c: Likewise.
9960 * config/rs6000/darwin-ldouble.c: Likewise.
9961 * config/rs6000/rs6000.md: Likewise.
9963 2004-01-12 David Edelsohn <edelsohn@gnu.org>
9965 * config/rs6000/rs6000.c (rs6000_init_libfuncs): Add AIX
9966 TFmode to SImode libfuncs.
9968 2004-01-12 Roger Sayle <roger@eyesopen.com>
9971 * varasm.c (assemble_alias): Remove weak aliases from weak_decls.
9973 2004-01-12 Jan Hubicka <jh@suse.cz>
9976 * loop.c (insert_loop_mem): Preffer VOLATILE memory references to be
9980 * cfgcleanup.c (label_is_jump_target_p): Move to...
9981 * rtlanal.c (label_is_jump_target_p): ... here.
9982 * cfgrtl.c (cfg_layout_redirect_edge_and_branch): Fix redirecting of fallthru
9983 edges unified with branch edges.
9985 2004-01-12 Richard Earnshaw <rearnsha@arm.com>
9987 * simplify-rtx.c (simplify_immed_subreg): Correctly extract the
9988 high word of an integral CONST_DOUBLE.
9990 2004-01-12 Paul Brook <paul@codesourcery.com>
9992 * simplify-rtx.c (simplify_plus_minus): Always generate canonical form.
9994 2004-01-12 J"orn Rennecke <joern.rennecke@superh.com>
9997 * sh-protos.h (check_use_sfunc_addr): Declare.
9998 * sh.c (extract_sfunc_addr, check_use_sfunc_addr): New functions.
9999 * sh.md (use_sfunc_addr): Use check_use_sfunc_addr in insn predicate.
10001 2004-01-12 Jan Hubicka <jh@suse.cz>
10003 * alias.c: Invlude varray.h
10004 (alias_sets): Turn into varray.
10005 (get_alias_set_entry): Use VARRAY; mark inline.
10006 (mems_in_disjoint_alias_sets_p): Mark inline.
10007 (record_alias_subset): Use varray.
10008 (init_alias_once): Initialize varray.
10009 (new_alias_set): Grow array.
10010 * varray.c: Make VARRAY_GENERIC_PTR non GTYized.
10012 2004-01-12 Jan Hubicka <jh@suse.cz>
10014 Partial fix for PR opt/10776 II
10015 * cselib.c: Include params.h
10016 (cselib_invalidate_mem): Limit amount of nonconflicting memory
10018 * params.def (PARAM_MAX_CSELIB_MEMORY_LOCATIONS): New.
10019 * Makefile.in (cselib.o): Depend on params.h
10021 2004-01-12 Richard Sandiford <rsandifo@redhat.com>
10023 * combine.c (combine_simplify_rtx): Don't pass VOIDmode to
10024 simplify_unary_operation if the operand has a known mode.
10026 2004-01-12 Hartmut Penner <hpenner@de.ibm.com>
10029 * gcc/config/rs6000/rs6000.c (word_offset_memref_operand): New
10030 predicate to handle 'ld' conform addresses.
10031 * gcc/config/rs6000/rs6000.h (EXTRA_CONSTRAINT): New 'Y'
10033 (EXTRA_MEMORY_CONSTRAINT): Tell reload which constraint
10034 are memory contraints.
10035 * gcc/config/rs6000/rs6000-protos.h (word_offset_memref_operand):
10037 * gcc/config/rs6000/rs6000.md (*movdf_hardfloat64):
10038 Change 'o' to 'Y' constraint.
10039 (*movdf_softfloat64): Ditto.
10041 2004-01-12 Bernardo Innocenti <bernie@develer.com>
10043 * gcc/config/m68k/m68k.md: Switch from the "*..." syntax to the
10044 brace-enclosed syntax in all C output statements.
10046 2004-01-12 David Edelsohn <edelsohn@gnu.org>
10049 * config/rs6000/rs6000.c (rs6000_output_function_epilogue):
10050 Objective-C language type value is 14.
10052 2004-01-12 Markus F.X.J. Oberhumer <markus@oberhumer.com>
10055 * config/m68k/fpgnulib.c: Fix `-mshort' bugs: Use `long' instead of
10056 `int' in a number of places to make sure we always have a SImode
10057 and not a HImode. Add a 'L' suffix to a number of constants.
10059 2004-01-11 John David Anglin <dave.anglin@nrc-cnrc.gc.ca>
10061 * pa.c: Don't include obstack.h.
10063 * pa.md: Correct constraint in pattern for loading PIC label address.
10065 2004-01-11 Kaz Kojima <kkojima@gcc.gnu.org>
10067 * config/sh/linux.h (ASM_PREFERRED_EH_DATA_FORMAT): Undefine
10070 2004-01-11 Steven Bosscher <stevenb@suse.de>
10073 * toplev.c (rest_of_handle_inline): Also consider functions
10074 for deferral if the language is GNU F77.
10076 2004-01-11 Zack Weinberg <zack@codesourcery.com>
10078 * c-decl.c (diagnose_arglist_conflict): Add missing space to
10079 diagnostic messages.
10081 2004-01-11 Jakub Jelinek <jakub@redhat.com>
10083 PR middle-end/13392
10084 * builtins.c (expand_builtin_expect_jump): Handle conditional jumps
10085 to drop through label. Don't fall back to SCC even when conditional
10086 jump has not been found.
10088 2004-01-11 Jan Hubicka <jh@suse.cz>
10090 * invoke.texi: Fix syntax error in previous patch.
10092 Partial fix for PR opt/10776
10093 * Makefile.in (reload.o): Include param.h
10094 * params.def (PARAM_MAX_RELOAD_SEARCH_INSNS): New parameter.
10095 * reload.c: Include params.h.
10096 (find_equiv_reg): Work limiting check.
10097 * invoke.texi: Document.
10099 2004-01-11 Richard Sandiford <rsandifo@redhat.com>
10101 * config/mips/mips.c (mips_symbolic_constant_p): Don't allow
10102 out-of-bounds accesses to string constants. Simplify mips16
10105 2004-01-11 Richard Sandiford <rsandifo@redhat.com>
10107 PR optimization/13469
10108 * toplev.c (rest_of_compilation): Call purge_all_dead_edges after
10109 reload_cse_regs (-fnon-call-exceptions only).
10111 2004-01-11 Kazu Hirata <kazu@cs.umass.edu>
10113 * config/mcore/lib1.asm: Fix comment formatting.
10114 * config/mcore/mcore-elf.h: Likewise.
10115 * config/mcore/mcore.c: Likewise.
10116 * config/mcore/mcore.h: Likewise.
10117 * config/mcore/mcore.md: Likewise.
10119 2004-01-10 Zack Weinberg <zack@codesourcery.com>
10121 * c-decl.c (duplicate_decls): Break apart into...
10122 (diagnose_arglist_conflict, validate_proto_after_old_defn)
10123 (locate_old_defn, diagnose_mismatched_decls, merge_decls):
10124 ... these new functions. Restructure for comprehensibility.
10125 Remove various archaic special cases. Always report the
10126 location of the previous declaration when a diagnostic is issued.
10127 (redeclaration_error_message): Fold into diagnose_mismatched_decls.
10128 (match_builtin_function_types): Delete unnecessary forward declaration.
10130 2004-01-10 Zack Weinberg <zack@codesourcery.com>
10132 * genautomata.c (make_automaton, NDFA_to_DFA):
10133 Print progress bars with '.' characters instead of '*'.
10134 (build_automaton): Change notes to match.
10136 2004-01-10 Kazu Hirata <kazu@cs.umass.edu>
10138 * config/m32r/m32r.md: Use define_constants for unspec and
10141 2004-01-10 Jan Hubicka <jh@suse.cz>
10144 * expr.c (expand_expr_real): More curefully expand union casts.
10146 2004-01-10 Kazu Hirata <kazu@cs.umass.edu>
10148 * config/m32r/m32r.md (flush_icache): Use 1 for
10151 2004-01-10 David Edelsohn <edelsohn@gnu.org>
10152 James E Wilson <wilson@specifixinc.com>
10155 * dbxout.c (dbxout_symbol): Remove initialization of
10156 current_sym_code, current_sym_value, and current_sym_addr.
10157 (dbxout_symbol_location): Same.
10158 (dbxout_prepare_symbol): Zero current_sym_code,
10159 current_sym_value, and current_sym_addr.
10161 2004-01-10 Richard Sandiford <rsandifo@redhat.com>
10163 * tree.c (get_unwidened): Reorder conditions so that the null pointer
10164 check is done first.
10166 2004-01-09 Eric Christopher <echristo@redhat.com>
10168 * toplev.c (rest_of_handle_cfg): Add reg_scan pass
10169 if we're running mark_constant_function.
10171 2004-01-09 Jeff Bailey <jbailey@nisa.net>
10174 * config/t-gnu: Rename SYSTEM_HEADER_DIR to NATIVE_SYSTEM_HEADER_DIR.
10176 2004-01-09 Andrew Pinski <pinskia@physics.uc.edu>
10179 * dbxout.c (dbxout_type_fields): Return if any item is
10180 error_mark_node or the type is error_mark_node.
10182 2004-01-09 Geoffrey Keating <geoffk@apple.com>
10184 * config/rs6000/darwin-ldouble.c: Add big comment explaining
10185 exactly what is expected as a 'long double'.
10186 (_xlqadd): When a value to be returned is representable as a
10187 'double', just return it directly, do not construct it using a union.
10188 Also, correct final fixup.
10189 (_xlqmul): Likewise.
10190 (_xlqdiv): Likewise.
10191 * real.c (encode_ibm_extended): Make consistent with darwin-ldouble.c.
10193 * config/rs6000/rs6000.md (fix_trunctfdi2): Delete.
10195 2004-01-09 Richard Henderson <rth@redhat.com>
10197 * recog.c (constrain_operands): Validate mem operands.
10199 2004-01-09 James E Wilson <wilson@specifixinc.com>
10201 * gcc.c (init_spec): Remove -lunwind from shared case.
10202 * conifg/ia64/t-hpux (SHLIB_LINK): Add -lunwind.
10204 2004-01-09 Steve Ellcey <sje@cup.hp.com>
10206 * configure.ac: (gcc_cv_ld_hidden) Set to true for ia64*-*-hpux*.
10207 * configure: Regenerate
10209 2004-01-09 Joseph S. Myers <jsm@polyomino.org.uk>
10212 * c-typeck.c (build_c_cast): If pedantic, warn for conversions
10213 between function and object pointers.
10214 (digest_init): When comparing a pointer to function type to the
10215 target type, only apply TREE_TYPE once to the pointer to function
10217 * except.c (for_each_eh_label_1): Treat data as a pointer to a
10218 function pointer rather than casting it to a function pointer.
10219 (for_each_eh_label): Update caller.
10220 * recog.h (struct insn_data): Use a struct or union for output.
10221 * genoutput.c (output_insn_data): Update.
10222 * final.c (get_insn_template): Update.
10224 2004-01-09 Mark Mitchell <mark@codesourcery.com>
10226 * expr.h (expand_expr): Make it a macro, not a function.
10227 (expand_expr_real): New function.
10228 * expr.c (store_expr): Adjust logic for deciding whether or not to
10229 copy the value returned by expand_expr.
10230 (expand_expr): Rename to ...
10231 (expand_expr_real): ... this. Add alt_rtl parameter. Adjust
10232 calls to language hooks.
10233 * c-common.h (c_expand_expr): Adjust prototype.
10234 * c-common.c (c_expand_expr): Add alt_rtl parameter.
10235 * langhooks-def.h (lhd_expand_expr): Change prototype.
10236 * langhooks.c (lhd_expand_expr): Add all_rtl parameter.
10237 * langhooks.h (lang_hooks): Change type of expand_expr.
10238 * stmt.c (stmt_status): Add x_last_expr_alt_rtl.
10239 (last_expr_alt_rtl): Likewise.
10240 (expand_expr_stmt_value): Set last_expr_alt_rtl.
10241 (clear_last_expr): Clear it.
10242 (expand_end_stmt_expr): Set RTL_EXPR_ATL_RTL.
10243 (expand_end_bindings): Save and restor last_expr_alt_rtl.
10244 * tree.def (RTL_EXPR): Give it an additional operand.
10245 * tree.h (RTL_EXPR_ALT_RTL): New macro.
10247 2004-01-09 Kazuhiro Inaoka <inaoka.kazuhiro@renesas.com>
10249 * config/m32r/m32r.h (TARGET_CPU_CPP_BUILTINS): Add __m32r__.
10250 * config/m32r/m32r.c (call26_operand): Allow in PIC mode.
10252 2004-01-09 Kazu Hirata <kazu@cs.umass.edu>
10255 * config/m32r/m32r.md: Replace (reg:SI 17) with (reg:CC 17)
10256 or (ne:SI (reg:CC 17) (const_int 0)).
10257 Be specific about modes wherever possible.
10259 2004-01-09 Kazu Hirata <kazu@cs.umass.edu>
10261 * config/m32r/m32r.c (m32r_expand_block_move): Call
10262 gen_movestrsi_internal with two more arguments.
10263 (m32r_output_block_move): Adjust operand numbers.
10264 Properly update the source and destination pointers.
10265 * config/m32r/m32r.md (movstrsi_internal): Use 'r' instead of
10266 'r+'. Change the set detinations to match_operand.
10268 2004-01-09 Kazu Hirata <kazu@cs.umass.edu>
10270 * final.c (FIRST_INSN_ADDRESS): Remove.
10271 (shorten_branches): Don't use FIRST_INSN_ADDRESS.
10272 * system.h (FIRST_INSN_ADDRESS): Poison.
10273 * config/avr/avr.h: Remove a comment about FIRST_INSN_ADDRESS.
10274 * config/m32r/m32r-protos.h: Remove the prototype for
10275 m32r_first_insn_address.
10276 * config/m32r/m32r.c (m32r_first_insn_address): Remove.
10277 * config/m32r/m32r.h (FIRST_INSN_ADDRESS): Likewise.
10278 * doc/md.texi (FIRST_INSN_ADDRESS): Likewise.
10280 2004-01-09 J. Brobecker <brobecker@gnat.com>
10282 * dwarf2out.c (gen_enumeration_type_die): Return the DIE that
10284 (is_ada_subrange_type): DIEs for enumeration subtypes should be
10285 emitted as subrange types too.
10286 (subrange_type_die): Add handling of enumeration subtypes.
10288 2004-01-08 Richard Henderson <rth@redhat.com>
10291 Revert: Sat Mar 30 14:08:55 CET 2002 Jan Hubicka <jh@suse.cz>
10292 * i386.c (aligned_operand): Be prepared for SUBREGed registers.
10293 (ix86_decompose_address): Use REG_P instead of GET_CODE (...) == REG.
10294 (ix86_address_cost): Be prepared for SUBREGed registers.
10295 (legitimate_address_p): Accept SUBREGed registers.
10297 2004-01-08 Kelley Cook <kcook@gcc.gnu.org>
10299 * Makefile.in: Rename configure.in to configure.ac
10300 * doc/sourcebuild.texi: Likewise.
10301 * configure: Regenerate.
10302 * config.in: Regenerate.
10304 2004-01-08 Stuart Hastings <stuart@apple.com>
10306 * config/i386/i386.md: Typos in MMX/SSE immediate shifts.
10308 2004-01-08 Jan Hubicka <jh@suse.cz>
10310 * cgraphunit.c (cgraph_decide_inlining): Fix typo.
10312 2004-01-08 Geoffrey Keating <geoffk@apple.com>
10314 * config/rs6000/rs6000.md (cmptf_internal1): Correct branch offset.
10315 (UNSPEC_FIX_TRUNC_TF): New constant.
10316 (movtf_internal): Make splitter active only when insn is active.
10317 (extenddftf2): Rewrite to properly load zero into low part.
10318 (extenddftf2_internal): New.
10319 (extendsftf2): Rewrite.
10320 (truncdftf2): Correct length.
10321 (floatditf2): Delete.
10322 (fix_trunc_helper): New.
10323 (fix_trunctfdi2): Use fix_trunc_helper.
10324 (fix_trunctfsi2): Likewise.fix_trunc
10325 (fix_trunctfsi2_internal): New.
10327 * config/rs6000/rs6000.c (legitimate_lo_sum_address_p): lo_sum
10328 addresses are legitimate on Darwin even when flag_pic.
10329 (rs6000_legitimize_reload_address) [TARGET_MACHO]: Don't create
10330 non-offsettable addresses for loads of TFmode constants.
10332 2004-01-08 Kazuhiro Inaoka <inaoka.kazuhiro@renesas.com>
10334 * config/m32r/m32r.h (ASM_OUTPUT_ALIGNED_BSS): Actually emit
10335 variables in the appropriate bss section.
10337 2004-01-09 Alan Modra <amodra@bigpond.net.au>
10339 * config/rs6000/linux64.h (SUBSUBTARGET_OVERRIDE_OPTIONS): Ensure
10340 target_flags has MASK_POWERPC64 when -m64.
10341 * config/rs6000/rs6000.c (processor_target_table): Add MASK_POWERPC64
10342 to 620, 630, power3, power4 and rs64a entries.
10343 * config/rs6000/rs6000.h (MASK_64BIT): Expand comment.
10345 2004-01-08 Richard Sandiford <rsandifo@redhat.com>
10347 * simplify-rtx.c (simplify_immed_subreg): Fix construction of
10348 floating-point constants.
10350 2004-01-08 J. Brobecker <brobecker@gnat.com>
10352 * dwarf2out.c (subrange_type_die): Add context_die parameter.
10353 Create the subrange_type DIE using the given context DIE.
10354 (modified_type_die): Update call to subrange_type_die.
10356 2004-01-08 Zack Weinberg <zack@codesourcery.com>
10358 * dwarf2.h, unwind-dw2-fde.h, unwind-pe.h, unwind.h:
10359 Add multiple-include guard.
10361 2004-01-08 Hartmut Penner <hpenner@de.ibm.com>
10363 * gcc/config/rs6000/rs6000.c (easy_vector_constant): Accept
10364 all vector constant loadable by vsplt*.
10365 (output_vec_const_move): Likewise.
10367 2004-01-07 Joseph S. Myers <jsm@polyomino.org.uk>
10370 * c-typeck.c (comptypes): Only treat enumerated types in the same
10371 translation unit as compatible with each other when they are the
10373 * doc/extend.texi: Update.
10375 2004-01-07 Joseph S. Myers <jsm@polyomino.org.uk>
10378 * c-decl.c (grokdeclarator): Take type qualifiers of typedefed
10379 array type from the array element type.
10381 2004-01-07 Alan Modra <amodra@bigpond.net.au>
10383 * config/rs6000/rs6000.c (rs6000_dbx_register_number): New function.
10384 * config/rs6000/rs6000-protos.h (rs6000_dbx_register_number): Declare.
10385 * config/rs6000/rs6000.h (DWARF_FRAME_REGNUM): Define.
10386 (DWARF_REG_TO_UNWIND_COLUMN): Correct column adjustment and comment.
10387 * config/rs6000/sysv4.h (DBX_REGISTER_NUMBER): Define.
10389 2004-01-06 Eric Christopher <echristo@redhat.com>
10391 * config/mips/mips.h (MDEBUG_ASM_SPEC): Change for dwarf2 default.
10392 (DWARF2_DEBUGGING_INFO): Define.
10393 (PREFERRED_DEBUGGING_TYPE): Set to dwarf2.
10394 * config/mips/openbsd.h (PREFERRED_DEBUGGING_TYPE): Remove.
10395 * config/mips/iris6.h (SUBTARGET_ASM_DEBUGGING_SPEC): Only pass -g0
10397 (SUBTARGET_ASM_OPTIMIZING_SPEC): Only pass O0 for irix as.
10398 * config/mips/iris6gas.h (MDEBUG_ASM_SPEC): Remove.
10399 * config/mips/iris5gas.h: Ditto.
10400 (DBX_DEBUGGING_INFO): Remove.
10401 (DWARF2_DEBUGGING_INFO): Ditto.
10402 (MIPS_DEBUGGING_INFO): Ditto.
10403 (PREFERRED_DEBUGGING_TYPE): Ditto.
10404 * config/mips/elf.h (DWARF2_DEBUGGING_INFO): Remove.
10405 (PREFERRED_DEBUGGING_TYPE): Ditto.
10406 (SUBTARGET_ASM_DEBUGGING_SPEC): Ditto.
10407 * config/mips/elf64.h: Ditto.
10409 2004-01-06 Jan Hubicka <jh@suse.cz>
10411 * Makefile.in (STAGEPROFILE_FLAGS_TO_PASS): Use -fprofile-generate.
10412 (STAGEFEEDBACK_FLAGS_TO_PASS): Use -fprofile-use.
10414 2004-01-06 Geoffrey Keating <geoffk@apple.com>
10416 * config/rs6000/t-darwin (LIB2FUNCS_EXTRA): Compile darwin-ldouble.c.
10417 (TARGET_LIBGCC2_CFLAGS): Use -mlong-double-128.
10418 * config/rs6000/darwin-ldouble.c: New.
10420 * emit-rtl.c (gen_lowpart_common): Use simplify_gen_subreg
10422 (constant_subword): Delete.
10423 * rtl.h (constant_subword): Delete prototype.
10424 (immed_double_const): Is not in varasm.c.
10425 * simplify-rtx.c (simplify_immed_subreg): New.
10426 (simplify_subreg): Use simplify_immed_subreg.
10428 * config/rs6000/rs6000.md (floatsitf2): Use expand_float rather
10429 than trying to generate RTL directly.
10430 (fix_trunctfsi2): Use expand_fix rather than trying to generate
10433 * dwarf2out.c (add_const_value_attribute): Remove incorrect comment.
10435 2004-01-06 David Edelsohn <edelsohn@gnu.org>
10437 * config/rs6000/xcoff.h (EXTRA_SECTION_FUNCTIONS): Split each
10438 function into a separate macro.
10439 (read_only_data_section): Add void argument.
10440 (private_data_section): Same.
10441 (read_only_private_data_section): Same.
10442 (toc_section): Same.
10444 2004-01-06 Jan Hubicka <jh@suse.cz>
10446 * invoke.texi: Remove typo in last change.
10449 * config.gcc: Accept opteron and athlon-64 as variants
10451 * i386.c (override_options): Likewise.
10452 * invoke.texi (i386 -mtune): Expand documentation.
10454 2004-01-06 Kazu Hirata <kazu@cs.umass.edu>
10456 * alias.c: Fix comment typos.
10457 * builtins.c: Likewise.
10460 * dominance.c: Likewise.
10461 * dwarf2out.c: Likewise.
10462 * emit-rtl.c: Likewise.
10463 * expr.c: Likewise.
10464 * final.c: Likewise.
10465 * fold-const.c: Likewise.
10466 * gcse.c: Likewise.
10467 * genattrtab.c: Likewise.
10468 * genrecog.c: Likewise.
10469 * gensupport.c: Likewise.
10470 * ggc-zone.c: Likewise.
10471 * integrate.c: Likewise.
10472 * local-alloc.c: Likewise.
10473 * loop.c: Likewise.
10474 * recog.c: Likewise.
10475 * regmove.c: Likewise.
10476 * reg-stack.c: Likewise.
10477 * reorg.c: Likewise.
10478 * rtlanal.c: Likewise.
10480 * sched-ebb.c: Likewise.
10481 * simplify-rtx.c: Likewise.
10482 * toplev.c: Likewise.
10483 * varasm.c: Likewise.
10485 2004-01-06 Kazu Hirata <kazu@cs.umass.edu>
10487 * doc/install.texi: Fix typos.
10488 * doc/invoke.texi: Likewise.
10489 * doc/md.texi: Likewise.
10491 2004-01-06 Kazuhiro Inaoka <inaoka.kazuhiro@renesas.com>
10493 * config/m32r/m32r.h (TRAMPOLINE_LINE_SIZE): Changed
10495 2004-01-06 Jan Hubicka <jh@suse.cz>
10497 * i386.c (init_cumulative_args): Add handling of MMX_REGPARM.
10498 (function_arg_advance): Do not pass aggregates in SSE; deal handling
10500 (function_arg): Add new warnings about ABI changes; fix SSE_REGPARM;
10502 * i386.h (ix86_args): Add mmx_words/mmx_regs/mmx_regno fields.
10503 (SSE_REGPARM_MAX): Default to 3 on i386 -msse ABI.
10504 (MMX_REGPARM_MAX): Similarly for -mmmx.
10506 2004-01-05 Kazu Hirata <kazu@cs.umass.edu>
10508 * config/sh/linux.h: Fix comment formatting.
10509 * config/sh/netbsd-elf.h: Likewise.
10510 * config/sh/sh.c: Likewise.
10511 * config/sh/sh.h: Likewise.
10512 * config/sh/vxworks.h: Likewise.
10514 2004-01-05 Kazu Hirata <kazu@cs.umass.edu>
10516 * system.h (ASM_OUTPUT_MAIN_SOURCE_FILENAME): Poison.
10517 * toplev.c (output_file_directive): Don't use
10518 ASM_OUTPUT_MAIN_SOURCE_FILENAME.
10520 2004-01-05 Steven Bosscher <s.bosscher@student.tudelft.nl>
10522 * toplev.c: Fix broken checkin of 2003-12-30.
10524 2004-01-05 Daniel Berlin <dberlin@dberlin.org>
10526 * ggc-zone.c: Remove everything in #ifdef USING_MALLOC_PAGE_GROUPS
10527 (USING_MMAP): We don't support non-mmap.
10528 (struct alloc_chunk): Steal 1 bit from typecode, use it to mark
10530 (struct page_entry): Remove bytes_free.
10531 (struct page_table_chain): Remove.
10532 (struct globals): Remove page_table member.
10533 (loookup_page_table_entry): Function deleted.
10534 (set_page_table_entry): Ditto.
10535 (ggc_allocated_p): No longer need page table lookups.
10536 (ggc_marked_p): Ditto.
10537 (alloc_small_page): Don't care about bytes_free anymore.
10538 (alloc_large_page): Round up size.
10539 (ggc_alloc_zone_1): Mark large objects as such, and calculate
10540 their size the new way.
10541 Remove page table lookups and setting.
10542 (ggc_get_size): Calculate large object size the new way.
10543 (sweep_pages): Redo to account for fact that we no longer have
10545 (ggc_collect): No longer need to reincrement bytes_free.
10546 (ggc_pch_alloc_object): Handle new large objects properly.
10547 (ggc_pch_read): Put PCH stuff into it's own uncollected zone.
10549 2004-01-05 Kazu Hirata <kazu@cs.umass.edu>
10551 * doc/invoke.texi: Remove a page break.
10553 2004-01-05 Kazu Hirata <kazu@cs.umass.edu>
10555 * config/avr/avr.c (avr_output_function_prologue): Remove an
10556 extra pair of curly braces.
10558 2004-01-05 Kazu Hirata <kazu@cs.umass.edu>
10560 * config/mn10300/mn10300.c: Fix comment formatting.
10561 * config/mn10300/mn10300.h: Likewise.
10563 2004-01-05 Richard Kenner <kenner@vlsi1.ultra.nyu.edu>
10565 * tree.h: Update documentation on nothrow_flag.
10566 * print-tree.c (print_node): Print TREE_NOTHROW as "align-ok" for
10569 2004-01-05 Kazu Hirata <kazu@cs.umass.edu>
10571 * doc/invoke.texi: Remove traces of dead ports.
10573 2004-01-05 Richard Sandiford <rsandifo@redhat.com>
10575 * doc/invoke.texi: Add documentation for the MIPS -mexplicit-relocs
10578 2004-01-05 Richard Sandiford <rsandifo@redhat.com>
10581 * coverage.c (coverage_counter_alloc): Set SYMBOL_FLAG_LOCAL for
10583 * config/mips/mips.c (INTERNAL_SYMBOL_P): Delete.
10584 (mips_classify_symbol): Always treat SYMBOL_REF_FLAG as indicating
10585 string constants if TARGET_MIPS16. Use SYMBOL_REF_DECL to check
10586 the binding of decl symbols, otherwise check SYMBOL_REF_LOCAL_P.
10587 (mips_symbol_insns): Don't trust the local/global classification.
10588 (m16_usym8_4, m16_usym5_4): Same mips16 change as mips_classify_symbol.
10589 (override_options): Make -mabicalls -fno-unit-at-a-time imply
10590 -mno-explicit-relocs.
10591 (mips_encode_section_info): Don't use SYMBOL_REF_FLAG to distinguish
10592 between local and global symbols.
10594 2004-01-05 Richard Sandiford <rsandifo@redhat.com>
10596 * config/mips/mips-protos.h (mips_dangerous_for_la25_p): Declare.
10597 (mips_preferred_reload_class): Declare.
10598 * config/mips/mips.h (DANGEROUS_FOR_LA25_P): Replace with function.
10599 (EXTRA_CONSTRAINT): Update accordingly.
10600 (PREFERRED_RELOAD_CLASS): Use mips_preferred_reload_class.
10601 * config/mips/mips.c (mips_dangerous_for_la25_p): New function.
10602 (mips_preferred_reload_class): New function. Prefer LEA_REGS if
10603 mips_dangerous_for_la25_p.
10604 (mips_secondary_reload_class): Use LEA_REGS rather than GR_REGS
10605 if mips_dangerous_for_la25_p.
10607 2004-01-05 Bernardo Innocenti <bernie@develer.com>
10609 * config/m68k/m68k.c (output_andsi3): Fix signed/unsigned comparison
10612 2004-01-04 Nathanael Nerode <neroden@gcc.gnu.org>
10614 * configure.ac: Use AC_PROG_CPP_WERROR.
10615 * configure: Regenerate.
10617 2004-01-04 Zack Weinberg <zack@codesourcery.com>
10619 * .cvsignore: Add autom4te.cache.
10621 2004-01-04 Richard Sandiford <rsandifo@redhat.com>
10623 * doc/invoke.texi: Revamp documentation of MIPS options. Remove
10624 -mabi=meabi, -mabi-fake-default, -mmips-as, -mgas, -mmips-tfile,
10625 -m4650, -mfix7000 and -(m)no-crt0. Put endianness options first,
10626 then architecture options, then ABI options. General rewording.
10628 2004-01-04 Joseph S. Myers <jsm@polyomino.org.uk>
10631 * doc/extend.texi: Clarify definition of malloc attribute.
10633 2004-01-04 Jan Hubicka <jh@suse.cz>
10635 * Makefile.in (cgraph.o, cgraphunit.o): Add intl.h dependency.
10636 * cgraph.c (create_edge, dump_cgraph): Update to use inline_failed
10637 * cgraph.h (cgraph_edge): Replace inline_call by inline_failed
10638 (cgraph_inline_p): Add extra argument reason.
10639 * cgraphunit.c: Minor formating fixes.
10640 cgraph_first_inlined_callee): New functions.
10641 (record_call_1): Record builtins too.
10642 (cgraph_analyze_function): Update inline_failed messages.
10643 (cgraph_mark_functions_to_output, cgraph_expand_function, cgraph_inlined_into,
10644 cgraph_inlined_callees, cgraph_estimate_growth): Update to use inline_failed.
10645 (cgraph_check_inline_limits): Likewise; Add argument reason.
10646 (cgraph_set_inline_failed): New static function.
10647 (cgraph_decide_inlining_of_small_function, cgraph_decide_inlining): Set
10649 (cgraph_inline_p): Add new argument reason.
10650 * tree-inline.c (expand_call_inline): Update warning.
10652 2004-01-03 Nathanael Nerode <neroden@gcc.gnu.org>
10654 * configure.ac: Replace AC_INIT, AC_OUTPUT, AC_CANONICAL_SYSTEM
10655 with modern equivalents.
10656 * configure: Regenerate.
10658 * configure.ac: Replace gcc_AC_CHECK_TYPE with AC_CHECK_TYPE.
10659 * aclocal.m4 (gcc_AC_CHECK_TYPE): Remove.
10660 * configure: Regenerate.
10662 * doc/install.texi: Note that 'gcc' is now a 2.57 directory.
10664 * configure.in: Rename to configure.ac.
10665 * configure.ac: Renamed from configure.in; make minimum necessary
10666 changes for autoconf 2.5x.
10667 * aclocal.m4: Make minimum necessary changes for autoconf 2.5x.
10668 * configure: Regenerate with autoconf 2.57.
10670 2004-01-03 Kazu Hirata <kazu@cs.umass.edu>
10672 * config/mips/linux.h: Fix comment formatting.
10673 * config/mips/mips.c: Likewise.
10674 * config/mips/mips.h: Likewise.
10675 * config/mips/mips.md: Likewise.
10676 * config/mips/netbsd.h: Likewise.
10677 * config/mips/windiss.h: Likewise.
10679 2004-01-02 Richard Henderson <rth@redhat.com>
10681 * config/i386/i386.md (fp constant pool splitter): Reorg suppression
10682 for sse and 387; add suppression for mmx.
10684 2004-01-02 Andrew Pinski <pinskia@physics.uc.edu>
10686 * loop.c (loop_optimize): Free all loops_info's mems.
10688 * c-typeck.c (finish_init): Free spelling_base before
10691 * cfgloop.c (flow_loops_find): Always free the sbitmap
10694 * predict.c (estimate_probability): Free bbs after being
10697 2004-01-02 Kazu Hirata <kazu@cs.umass.edu>
10699 * config/mn10300/mn10300.h (PREDICATE_CODES): Add
10700 const_8bit_operand and call_address_operand.
10702 2004-01-02 Jan Hubicka <jh@suse.cz>
10704 * cgraphunit.c (cgraph_optimize_function): Call optimize_inline_calls
10705 when there is nothing to inline but warnings are requested.
10706 (cgraph_decide_inlining): Fix memory leak.
10708 2004-01-02 Jan Hubicka <jh@suse.cz>
10710 * expr.c (store_constructor): Fix pasto in previous patch.
10712 2004-01-02 Kazu Hirata <kazu@cs.umass.edu>
10714 * config/i386/cygming.h: Fix comment formatting.
10715 * config/i386/djgpp.h: Likewise.
10716 * config/i386/gthr-win32.c: Likewise.
10717 * config/i386/i386-interix.h: Likewise.
10718 * config/i386/i386.c: Likewise.
10719 * config/i386/i386.h: Likewise.
10720 * config/i386/openbsd.h: Likewise.
10721 * config/i386/winnt.c: Likewise.
10722 * config/i386/xm-mingw32.h: Likewise.
10724 2004-01-02 Joseph S. Myers <jsm@polyomino.org.uk>
10726 * doc/gcc.texi, doc/invoke.texi, doc/install.texi: Update
10727 copyright and last modification dates.
10729 2004-01-02 Andreas Jaeger <aj@suse.de>, Gerald Pfeifer <gp@suse.de>
10731 * doc/install.texi (Specific): Mention x86_64.
10733 2004-01-01 Hans-Peter Nilsson <hp@bitrange.com>
10735 * builtins.c (expand_builtin_apply_args_1) [STACK_GROWS_DOWNWARD]:
10736 Call force_operand on plus_constant result.
10738 2004-01-01 Jan Hubicka <jh@suse.cz>
10740 * expmed.c (store_bit_field, extract_bit_field): Use new named patterns
10741 * expr.c (store_constructor): Use vec_init pattern.
10742 * genopinit.c (optabs): Initailize vec_set/vec_extract/vec_init.
10743 * optabs.h (optab_index): ADD OTI_vec_set/OTI_vec_extract/OTI_vec_init
10744 (vec_set_optab, vec_extract_optab, vec_init_optab): New.
10745 * i386.md (vec_setv2df, vec_extractv2df, vec_setv4sf, vec_extractv4sf):
10747 (sse2_unpc?pd): Fix pattern.
10748 (sse2_movlpd): Kill.
10749 (sse2_movsd): Deal with movlpd too.
10750 * i386.c (ix86_expand_builtin): Use sse2_movsd instead of sse2_movlpd.
10751 (ix86_expand_vector_init): New.
10752 * emmintrin.h (__mm_set_pd, __mm_set_ps): Use vector extensions.
10753 * md.texi (vec_set, vec_extract): Document
10755 2003-12-31 Jan Hubicka <jh@suse.cz>
10758 * recog.c (validate_replace_rtx_1): Take care for RTL sharing inside
10762 * toplev.c (dump_file_index): Reorder ce3 and bbro.
10763 (dump_file): Likewise.
10764 (rest_of_compilation): Likewise.
10767 * cgraph.c (cgraph_function_possibly_inlined): Even with
10768 flag_really_no_inline we inline always_inline functions.
10769 * cgraphunit.c (cgraph_analyze_function): Clear inlinable flag
10770 for non-always_inline functions when there is flag_really_no_inline.
10771 (cgraph_decide_inlining): Limit work done when not inlining.
10772 (cgraph_decide_inlining_incrementally): Likewise.
10773 (cgraph_optimize_function): Check whether something got inlined.
10774 * c-objc-common.c (c_disregard_inline_limits): Do not always inline
10775 extern inline functions when not inlining.
10777 * opts.c (decode_options): Disable crossjumping at -O1
10778 * invoke.texi (-O1): Document change.
10780 See ChangeLog.10 for earlier changes.