avr.h (AVR_HAVE_LPMX): New macro.
[gcc.git] / gcc / ChangeLog
1 2007-01-17 Anatoly Sokolov <aesok@post.ru>
2
3 * config/avr/avr.h (AVR_HAVE_LPMX): New macro.
4 (AVR_ENHANCED): Rename to ...
5 (AVR_HAVE_MUL): ... new.
6 (avr_enhanced_p): Rename to ...
7 (avr_have_mul_p): ... new.
8 (TARGET_CPU_CPP_BUILTINS): Use 'avr_have_mul_p' instead of
9 'avr_enhanced_p' for "__AVR_ENHANCED__". Define "__AVR_HAVE_MUL__".
10 * config/avr/avr.c (avr_enhanced_p): Rename to ...
11 (avr_have_mul_p): ... new.
12 (base_arch_s): Rename 'enhanced' to 'have_mul'.
13 (avr_override_options): Use 'avr_have_mul_p' and 'have_mul' instead of
14 'avr_enhanced_p' and 'enhanced'.
15 (ashlhi3_out, ashrhi3_out, lshrhi3_out, avr_rtx_costs): Use
16 AVR_HAVE_MUL instead of AVR_ENHANCED.
17 * avr.md (*tablejump_enh): Use AVR_HAVE_LPMX instead of AVR_ENHANCED.
18 (mulqi3, *mulqi3_enh, *mulqi3_call, mulqihi3, umulqihi3, mulhi3,
19 *mulhi3_enh, *mulhi3_call, mulsi3, *mulsi3_call): Use AVR_HAVE_MUL
20 instead of AVR_ENHANCED.
21 (*tablejump_enh): Use AVR_HAVE_LPMX instead of AVR_ENHANCED.
22 * libgcc.S: Use __AVR_HAVE_MUL__ instead of __AVR_ENHANCED__.
23 (__tablejump__): Use __AVR_HAVE_LPMX__ instead of __AVR_ENHANCED__.
24
25 2007-01-17 Ian Lance Taylor <iant@google.com>
26
27 * vec.h (VEC_reserve_exact): Define.
28 (vec_gc_p_reserve_exact): Declare.
29 (vec_gc_o_reserve_exact): Declare.
30 (vec_heap_p_reserve_exact): Declare.
31 (vec_heap_o_reserve_exact): Declare.
32 (VEC_OP (T,A,reserve_exact)): New static inline function, three
33 versions.
34 (VEC_OP (T,A,reserve)) [all versions]: Remove handling of
35 negative parameter.
36 (VEC_OP (T,A,alloc)) [all versions]: Call ...reserve_exact.
37 (VEC_OP (T,A,copy)) [all versions]: Likewise.
38 (VEC_OP (T,a,safe_grow)) [all versions]: Likewise.
39 * vec.c (calculate_allocation): Add exact parameter. Change all
40 callers.
41 (vec_gc_o_reserve_1): New static function, from vec_gc_o_reserve.
42 (vec_gc_p_reserve, vec_gc_o_reserve): Call vec_gc_o_reserve_1.
43 (vec_gc_p_reserve_exact, vec_gc_o_reserve_exact): New functions.
44 (vec_heap_o_reserve_1): New static function, from vec_heap_o_reserve.
45 (vec_heap_p_reserve, vec_heap_o_reserve): Call vec_heap_o_reserve_1.
46 (vec_heap_p_reserve_exact): New function.
47 (vec_heap_o_reserve_exact): New function.
48
49 2007-01-17 Jan Hubicka <jh@suse.cz>
50
51 * ipa-type-escape.c (look_for_casts): Revamp using handled_component_p.
52
53 2007-01-17 Eric Christopher <echristo@apple.com>
54
55 * config.gcc: Support core2 processor.
56
57 2007-01-16 Jan Hubicka <jh@suse.cz>
58
59 * tree-ssanames.c (release_dead_ssa_names): Instead of ggc_freeing
60 the names, just unlink the chain so we don't crash on dangling pointers
61 to dead SSA names.
62
63 2007-01-16 Jan Hubicka <jh@suse.cz>
64
65 * cgraph.h (cgraph_decide_inlining_incrementally): Kill.
66 * tree-pass.h: Reorder to make IPA passes appear toegher.
67 (pass_early_inline, pass_inline_parameters, pass_apply_inline): Declare.
68 * cgraphunit.c (cgraph_finalize_function): Do not compute inling
69 parameters, do not call early inliner.
70 * ipa-inline.c: Update comments. Include tree-flow.h
71 (cgraph_decide_inlining): Do not compute inlining parameters.
72 (cgraph_decide_inlining_incrementally): Return TODOs; assume to
73 be called with function context set up.
74 (pass_ipa_inline): Remove unreachable functions before pass.
75 (cgraph_early_inlining): Simplify assuming to be called from the
76 PM as local pass.
77 (pass_early_inline): New pass.
78 (cgraph_gate_ipa_early_inlining): New gate.
79 (pass_ipa_early_inline): Turn into simple wrapper.
80 (compute_inline_parameters): New function.
81 (gate_inline_passes): New gate.
82 (pass_inline_parameters): New pass.
83 (apply_inline): Move here from tree-optimize.c
84 (pass_apply_inline): New pass.
85 * ipa.c (cgraph_remove_unreachable_nodes): Verify cgraph after
86 transforming.
87 * tree-inline.c (optimize_inline_calls): Return TODOs rather than
88 doing them by hand.
89 (tree_function_versioning): Do not allocate dummy struct function.
90 * tree-inline.h (optimize_inline_calls): Update prototype.
91 * tree-optimize.c (execute_fixup_cfg): Export.
92 (pass_fixup_cfg): Remove
93 (tree_rest_of_compilation): Do not apply inlines.
94 * tree-flow.h (execute_fixup_cfg): Declare.
95 * Makefile.in (gt-passes.c): New.
96 * passes.c: Include gt-passes.h
97 (init_optimization_passes): New passes.
98 (nnodes, order): New static vars.
99 (do_per_function_toporder): New function.
100 (execute_one_pass): Dump current pass here.
101 (execute_ipa_pass_list): Don't dump current pass here.
102
103 2007-01-16 Janis Johnson <janis187@us.ibm.com>
104
105 * config/dfp-bit.c (dfp_compare_op): Return separate value for NaN.
106 (DFP_NE, DFP_LE, DFP_GE): Return false for NaN.
107
108 2007-01-16 David Edelsohn <edelsohn@gnu.org>
109
110 * config/rs6000/darwin-ldouble.c: Build file for SOFT_FLOAT.
111 (strong_alias): Define.
112 (__gcc_qmul): Provide non-FMA for soft-float.
113 (__gcc_qdiv): Same.
114 (__gcc_qneg): New.
115 (__gcc_qeq): New.
116 (__gcc_qle): New.
117 (__gcc_qge): New.
118 (__gcc_qunord): New.
119 (__gcc_stoq): New.
120 (__gcc_dtoq): New.
121 (__gcc_qtos): New.
122 (__gcc_qtod): New.
123 (__gcc_qtoi): New.
124 (__gcc_qtou): New.
125 (__gcc_itoq): New.
126 (__gcc_utoq): New.
127 (fmsub): New.
128 * config/rs6000/rs6000.c (rs6000_init_libfuncs): Initialize
129 soft-float functions.
130 * config/rs6000/libgcc-ppc-glibc.ver: Version soft-float symbols.
131 * config/rs6000/sysv4.h (SUBTARGET_OVERRIDE_OPTIONS): Do not warn
132 about long double soft float.
133
134 2007-01-16 Dorit Nuzman <dorit@il.ibm.com>
135 Tehila Meyzels <tehila@il.ibm.com>
136
137 * tree-vectorizer.h (is_pattern_stmt_p): New.
138 * tree-vect-analyze.c (vect_determine_vectorization_factor): Fix
139 formatting (tabs instead of spaces). Cleanup and clarify setting
140 of STMT_VINFO_VECTYPE. Call is_pattern_stmt_p.
141 * tree-vect-transform.c (vect_get_vec_def_for_operand): Fix typo.
142 (vectorizable_type_demotion): Check that types are integral.
143 (vectorizable_type_promotion): Likewise.
144 (vectorizable_store): Fix typo. Eliminate new-line at end of
145 comments.
146
147 2007-01-16 Jan Hubicka <jh@suse.cz>
148
149 * tree-ssanames.c (release_dead_ssa_names): Remove invalidated
150 cgraph edges too.
151
152 2007-01-15 Eric Christopher <echristo@apple.com>
153
154 * ifcvt.c: Include vec.h, vecprim.h.
155 (check_cond_move_block): New argument regs.
156 Reorganize. Add registers used to regs.
157 (cond_move_process_if_block): Use regs set above as
158 loop bounds.
159
160 2007-01-15 Eric Christopher <echristo@apple.com>
161
162 * config/darwin.h: Update copyright.
163 (TARGET_OPTION_TRANSLATE_TABLE): Add umbrella.
164 (LINK_COMMAND_SPEC): Add -u.
165 (LINK_SPEC): Fix umbrella for above.
166
167 2007-01-15 Joseph S. Myers <joseph@codesourcery.com>
168
169 * config/soft-fp/op-common.h, config/soft-fp/op-4.h: Update from
170 glibc CVS.
171
172 2007-01-15 Tom Tromey <tromey@redhat.com>
173
174 * doc/sourcebuild.texi (libgcj Tests): Don't mention jacks.
175 * doc/install.texi (Testing): Don't mention jacks.
176 (Configuration): Document --enable-java-maintainer-mode. Move
177 --with-java-home to libgcj-specific section. Document
178 --with-ecj-jar.
179 (Prerequisites): Mention --enable-java-maintainer-mode, ecj1.
180
181 2007-01-15 Jan Hubicka <jh@suse.cz>
182
183 * tree-ssa-dce.c (DCE_TODOs): New.
184 (propagate_necessity): Return if something changed.
185 (eliminate_unnecessary_stmts): Likewise.
186 (perform_tree_ssa_dce): Return TODO flags when needed.
187 (pass_dce, pass_dce_loop, pass_cd_dce): Remove TODO flags.
188
189 2007-01-15 Uros Bizjak <ubizjak@gmail.com>
190
191 * config/i386/i386.md (fyl2xxf3_i387): Rename from fyl2x_xf3.
192 (fyl2x_extend<mode>xf3_i387): New insn pattern.
193 (log<mode>2): Rename from logsf2 and logdf2 and macroize insn
194 insn patterns using X87MODEF12 mode macro. Extend operand 1
195 to XFmode. Use SSE_FLOAT_MODE_P to disable patterns for SSE math.
196 (log10<mode>2): Ditto.
197 (log2<mode>2): Ditto.
198 (log1p<mode>2): Ditto.
199 (logb<mode>2): Ditto.
200 (fyl2xp1xf3_i387): Rename from fyl2xp1_xf3.
201 (fyl2xp1_extend<mode>xf3_i387): New insn pattern.
202 (*fxtractxf3_i387): Rename from *fxtractxf3.
203 (fxtract_extend<mode>xf3_i387): New insn pattern.
204 (ilogbsi2): Use match_dup 3, not match_operand:XF 3.
205
206 * config/i386/i386.c (ix86_emit_i387_log1p): Use gen_fyl2xp1xf3_i387()
207 and gen_fyl2xxf3_i387().
208
209 2007-01-14 Zdenek Dvorak <dvorakz@suse.cz>
210
211 * loop-unswitch.c (unswitch_loop): Do not call fix_loop_placement.
212 * cfgloopmanip.c (fix_loop_placement): Made static. Use
213 get_loop_exit_edges. Changed return type to bool.
214 * cfgloop.h (fix_loop_placement): Declaration removed.
215
216 2007-01-14 Dorit Nuzman <dorit@il.ibm.com>
217
218 * param.h (MIN_VECT_LOOP_BOUND): New.
219 * params.def (MIN_VECT_LOOP_BOUND): New.
220 * tree-vectorizer.c (slpeel_tree_peel_loop_to_edge): Takes another
221 argument - minimum threshold for number of iterations.
222 * tree-vectorizer.h (slpeel_tree_peel_loop_to_edge): Add another
223 argument to declaration.
224 * tree-vect-analyze.c (vect_analyze_operations): Check value of
225 MIN_VECT_LOOP_BOUND.
226 * tree-vect-transform.c (vect_do_peeling_for_loop_bound): Call
227 slpeel_tree_peel_loop_to_edge with additional argument.
228 (vect_do_peeling_for_alignment): Likewise.
229 * doc/invoke.texi (min-vect-loop-bound): Document new param option.
230
231 2007-01-14 Uros Bizjak <ubizjak@gmail.com>
232
233 PR target/30413
234 * config/i386/i386.c (print_operand) ['z']: Output 'b' for
235 operands of size 1.
236
237 2007-01-14 Jan Hubicka <jh@suse.cz>
238
239 * tree-dfa.c (remove_referenced_var): New function.
240 * tree-ssa-live.c (remove_unused_locals): Walk referenced vars and
241 prune referenced vars list too.
242 * tree-flow.h (remove_referenced_var): Declare.
243
244 2007-01-14 Jan Hubicka <jh@suse.cz>
245
246 * tree-eh.c (add_stmt_to_eh_region_fn): Do not add call_exprs
247 separately.
248 (remove_stmt_from_eh_region_fn): Do not remove call_exprs.
249 (verify_eh_throw_stmt_node, verify_eh_throw_table_statements): Kill.
250 * except.h (verify_eh_throw_table_statements): Kill prototype.
251 * cfgexpand.c (expand_gimple_basic_block): Propagate Eh regions
252 into call exrepssions.
253 * tree-optimize.c (execute_free_cfg_annotatiosn): Do not call
254 eh trhow verifier.
255 * tree-cfg.c: Include pointer-set.h.
256 (verify_node_sharing): Work on pointer set.
257 (verify_eh_throw_stmt_node): New.
258 (verify_stmts): Use pointers sets, verify throw_stmt.
259
260 2007-01-13 Zdenek Dvorak <dvorakz@suse.cz>
261
262 * ipa-reference.c (analyze_function): Consider also addresses taken
263 in phi nodes.
264
265 2007-01-12 Roger Sayle <roger@eyesopen.com>
266
267 * c-typeck.c (null_pointer_constant_p): Replace use of
268 TREE_CONSTANT_OVERFLOW with TREE_OVERFLOW.
269 (build_c_cast): Likewise.
270
271 2007-01-12 Roger Sayle <roger@eyesopen.com>
272
273 * tree.h (force_fit_type_double): Remove unused final argument.
274 * c-common.c (constant_expression_warning): Replace use of
275 TREE_CONSTANT_OVERFLOW with TREE_OVERFLOW.
276 (convert_and_check): Likewise.
277 (shorten_compare): Update call to force_fit_type_double.
278 (c_common_truthvalue_conversion) <INTEGER_CST>: Use integer_zerop.
279 * convert.c (convert_to_pointer): Update call to
280 force_fit_type_double.
281 * fold-const.c (force_fit_type_double): Remove overflowed_const
282 argument.
283 (int_const_binop, fold_convert_const_int_from_int,
284 fold_convert_const_int_from_real, fold_div_compare,
285 fold_sign_changed_comparison, fold_unary, fold_negate_const,
286 fold_abs_const, fold_not_const): Remove the final argument from
287 calls to force_fit_type_double.
288
289 2007-01-12 Andrew Pinski <andrew_pinski@playstation.sony.com>
290
291 * configure.ac: Set insn to "nop" for spu-*-* also.
292 * configure: Regenerate.
293
294 2007-01-12 Olga Golovanevsky <olga@il.ibm.com>
295
296 * builtins.def : Add BUILT_IN_FREE.
297
298 2007-01-12 Jan Hubicka <jh@suse.cz>
299
300 PR tree-optimization/30443
301 * tree-inline.c (tree_function_versioning): Do not optimize when
302 cloning for inlining.
303
304 2007-01-12 Zdenek Dvorak <dvorakz@suse.cz>
305
306 * doc/loop.texi: Document recording of loop exits.
307 * cfgloopmanip.c (loopify, duplicate_loop): Use alloc_loop.
308 (update_single_exits_after_duplication,
309 update_single_exit_for_duplicated_loop,
310 update_single_exit_for_duplicated_loops): Removed.
311 (duplicate_loop_to_header_edge): Do not call
312 update_single_exits_after_duplication and
313 update_single_exit_for_duplicated_loops.
314 (loop_version): Do not update single_exit information.
315 (fix_loop_structure): Use record_loop_exits instead of
316 mark_single_exit_loops.
317 * tree-ssa-loop-manip.c (tree_transform_and_unroll_loop): Update
318 the lists of loop exits.
319 * cfghooks.c (redirect_edge_and_branch, redirect_edge_and_branch_force,
320 split_edge, merge_blocks): Update the lists of loop exits.
321 * modulo-sched.c (sms_schedule): Pass LOOPS_HAVE_RECORDED_EXITS to
322 loop_optimizer_init.
323 * loop-init.c (loop_optimizer_init): Call record_loop_exits instead
324 of mark_single_exit_loops.
325 (loop_optimizer_finalize): Call release_recorded_exits.
326 * tree-ssa-loop.c (tree_loop_optimizer_init): Pass
327 LOOPS_HAVE_RECORDED_EXITS to loop_optimizer_init.
328 * tree-vectorizer.c (slpeel_tree_duplicate_loop_to_edge_cfg): Do not
329 update single exit information.
330 * lambda-code.c (perfect_nestify): Ditto.
331 * cfgloop.c (flow_loop_free): Destroy the list of exits of the loop.
332 (mark_single_exit_loops): Removed.
333 (alloc_loop, loop_exit_hash, loop_exit_eq, loop_exit_free,
334 get_exit_descriptions, rescan_loop_exit, record_loop_exits,
335 dump_recorded_exit, dump_recorded_exits, release_recorded_exits): New
336 functions.
337 (get_loop_exit_edges, single_exit): Use recorded exit lists.
338 (add_bb_to_loop, remove_bb_from_loops): Update the lists of loop exits.
339 (verify_loop_structure): Verify consistency of the exit lists.
340 (flow_loops_find): Use alloc_loop. Initialize exits hash.
341 (set_single_exit): Removed.
342 * cfgloop.h (struct loop_exit): New function.
343 (struct loop): single_exit_ field replaced by exits field.
344 (LOOPS_HAVE_MARKED_SINGLE_EXITS): Replaced by LOOPS_HAVE_RECORDED_EXITS.
345 (struct loops): Added exits hash.
346 (mark_single_exit_loops, set_single_exit): Declaration removed.
347 (release_recorded_exits, record_loop_exits, rescan_loop_exit): Declare.
348
349 2007-01-12 Richard Sandiford <richard@codesourcery.com>
350
351 * doc/invoke.texi: Avoid use of @headitem.
352
353 2007-01-12 Richard Sandiford <richard@codesourcery.com>
354
355 * cse.c (cse_insn): Move HAVE_CC0 code after declarations.
356
357 2007-01-12 Richard Sandiford <richard@codesourcery.com>
358
359 * doc/install.texi: Fix m68k-*-* anchor and add m68k-*-* to the
360 list of targets.
361
362 2007-01-12 Nathan Sidwell <nathan@codesourcery.com>
363 Richard Sandiford <richard@codesourcery.com>
364
365 * doc/invoke.texi: Document -mno-bitfield, -mno-rtd and -mno-short.
366 * config/m68k/m68k.opt: Resort options.
367 (mbitfield, mrtd, mshort): Remove RejectNegative properties.
368
369 2007-01-12 Nathan Sidwell <nathan@codesourcery.com>
370 Richard Sandiford <richard@codesourcery.com>
371
372 * doc/invoke.texi: Document the macros that are defined by
373 m68k's -mtune and -mhard-float options.
374 * config/m68k/m68k-protos.h (m68k_cpp_cpu_ident) Declare.
375 (m68k_cpp_cpu_family): Likewise.
376 * config/m68k/m68k.h (TARGET_CPU_CPP_BUILTINS): Add a full set
377 of __ucfv*__ macros. Define __mcffpu__ if generating code for
378 ColdFire FPUs. Define __mcf_cpu_* and __mcf_family_* macros.
379 * config/m68k/m68k.c (m68k_cpp_cpu_ident): New function.
380 (m68k_cpp_cpu_family): Likewise.
381
382 2007-01-12 Richard Sandiford <richard@codesourcery.com>
383
384 * config/m68k/m68k.h (TARGET_CPU_CPP_BUILTINS): Treat all mc68*
385 macros besides mc68000 as tuning macros. Use a switch statement
386 to set them and mcpu32.
387
388 2007-01-12 Julian Brown <julian@codesourcery.com>
389
390 * config/m68k/m68k.h: Use TARGET_68040 instead of TARGET_68040_ONLY.
391 (TARGET_68040_ONLY): Rename to...
392 (TARGET_68040): ...this.
393 * config/m68k/m68k.c: Use TARGET_68040 instead of TARGET_68040_ONLY.
394 * config/m68k/m68k.md: Likewise.
395
396 2007-01-12 Julian Brown <julian@codesourcery.com>
397 Nathan Sidwell <nathan@codesourcery.com>
398 Richard Sandiford <richard@codesourcery.com>
399
400 * config.gcc (m680[012]0-*-*, m68k*-*-*): Set m68k_cpu_ident to
401 the -mcpu= argument associated with the --with-cpu setting.
402 Define M68K_DEFAULT_TUNE to the default -mtune= option,
403 if different from the one implied by the -mcpu setting.
404 Accept --with-cpu=FOO if FOO is listed in m68k-devices.def,
405 using mcpu=FOO as the default CPU option. Set target_cpu_default2.
406 * doc/invoke.texi: Mention ColdFire in the introduction to the
407 m68k options. Document the new -march, -mcpu, -mtune, -mdiv,
408 -mno-div and -mhard-float options. Make -m68881 a synonym for
409 -mhard-float. Document the previously-undocumented -m5206e,
410 -m528x, -m5307 and -m5407 options. Tweak the existing option
411 documentation for consistency.
412 * doc/install.texi: Mention new --with-cpu arguments.
413 * config/m68k/m68k.h (OPTION_DEFAULT_SPECS): Only use the
414 default CPU if neither -mcpu nor -march are specified.
415 (ASM_CPU_SPEC): Pass down -mcpu and -march options.
416 (TARGET_CPU_CPP_BUILTINS): Set __mcfisa*__ macros from
417 TARGET_ISA*. Set the legacy __mcf*__ cpu macros in the same way,
418 using m68k_tune to decide between families that implement the
419 same ISA. Use m68k_tune to set __mcfv4e__.
420 (FL_BITFIELD, FL_68881, FL_COLDFIRE, FL_CF_HWDIV, FL_CF_MAC)
421 (FL_CF_EMAC, FL_CF_EMAC_B, FL_CF_USP, FL_CF_FPU, FL_ISA_68000)
422 (FL_ISA_68010, FL_ISA_68020, FL_ISA_68040, FL_ISA_A, FL_ISA_B)
423 (FL_ISA_C, FL_ISA_MMU): New macros.
424 (MASK_COLDFIRE): Delete.
425 (TARGET_68010, TARGET_68020, TARGET_68040_ONLY, TARGET_COLDFIRE)
426 (TARGET_ISAB): Redefine in terms of m68k_cpu_flags.
427 (TARGET_68881, TARGET_COLDFIRE_FPU): Redefine in terms of m68k_fpu.
428 (TARGET_HARD_FLOAT): Do not define here.
429 (TARGET_ISAAPLUS, TARGET_ISAC): New macros.
430 (TUNE_68000): New macro.
431 (TUNE_68000_10): Redefine in terms of TUNE_68000 and TUNE_68010.
432 (TUNE_68010, TUNE_68030, TUNE_68040, TUNE_68060, TUNE_CPU32)
433 (TUNE_CFV2): Redefine in terms of m68k_tune.
434 (uarch_type, target_device, fpu_type): New enums.
435 (m68k_cpu, m68k_tune, m68k_fpu, m68k_cpu_flags): Declare.
436 * config/m68k/m68k.c (TARGET_DEFAULT): Remove MASK_68881.
437 (FL_FOR_isa_00, FL_FOR_isa_10, FL_FOR_isa_20, FL_FOR_isa_40)
438 (FL_FOR_isa_cpu32, FL_FOR_isa_a, FL_FOR_isa_aplus, FL_FOR_isa_b)
439 (FL_FOR_isa_c): New macros.
440 (m68k_isa): New enum.
441 (m68k_target_selection): New structure.
442 (all_devices, all_isas, all_microarchs): New tables.
443 (m68k_cpu_entry, m68k_arch_entry, m68k_tune_entry, m68k_cpu)
444 (m68k_tune, m68k_fpu, m68k_cpu_flags): New variables.
445 (MASK_ALL_CPU_BITS): Delete.
446 (m68k_find_selection): New function.
447 (m68k_handle_option): Handle -mcpu=, -march= and -mtune=.
448 Map the legacy target options to a combination of the new ones.
449 (override_options): Set m68k_cpu, m68k_tune, m68k_fpu and
450 m68k_cpu_flags. Handle M68K_DEFAULT_TUNE. Use m68k_cpu_flags
451 to derive default MASK_BITFIELD, MASK_CF_HWDIV and MASK_HARD_FLOAT
452 settings.
453 * config/m68k/m68k.opt (m5200, m5206e, m528x, m5307, m5407, mcfv4e)
454 (m68010, m68020, m68020-40, m68020-60, m68030, m68040): Remove Mask
455 properties.
456 (m68881, msoft-float): Change mask from 68881 to HARD_FLOAT.
457 (march=, mcpu=, mdiv, mhard-float, mtune=): New options.
458 * config/m68k/m68k-devices.def: New file.
459
460 2007-01-12 Richard Sandiford <richard@codesourcery.com>
461 Nathan Sidwell <nathan@codesourcery.com>
462
463 * config/m68k/m68k.h (ASM_CPU_SPEC, ASM_SPEC, EXTRA_SPECS)
464 (SUBTARGET_EXTRA_SPECS): New macros.
465 * config/m68k/linux.h (ASM_SPEC): Remove CPU flags;
466 use %(asm_cpu_spec) instead.
467 * config/m68k/m68k-none.h (ASM_SPEC): Likewise.
468 * config/m68k/openbsd.h (ASM_SPEC): Likewise.
469 * config/m68k/netbsd-elf.h (ASM_SPEC): Likewise.
470 (EXTRA_SPECS): Rename to...
471 (SUBTARGET_EXTRA_SPECS): ...this.
472
473 2007-01-12 Nathan Sidwell <nathan@codesourcery.com>
474 Richard Sandiford <richard@codesourcery.com>
475 Julian Brown <julian@codesourcery.com>
476
477 * config.gcc (m68k-*-aout*, m68k-*-coff*, m68020-*-elf*, m68k-*-elf*)
478 (m68k-*-uclinux*, m68k-*-linux*, m68k-*-rtems*): Set default_m68k_cpu
479 to the configuration's default CPU.
480 (m68010-*-netbsdelf*, m68k*-*-netbsdelf*, m68k*-*-openbsd*): Likewise.
481 Remove default masks.
482 (m680[012]0-*-*): Set the default with_cpu to the first part of
483 the target name.
484 (m68k*-*-*): Set the default with_cpu to m$default_m68k_cpu.
485 (m68k*-*-linux): Extend the --with-cpu handling to...
486 (m680[012]0-*-*, m68k*-*-*): ...these configurations. Allow m68000
487 and m68010. Don't set target_cpu_default2.
488 * doc/install.texi: Document --with-cpu for m68k.
489 * config/m68k/m68k.h (OPTION_DEFAULT_SPECS): Define.
490 * config/m68k/m68k-none.h (TARGET_CPU_DEFAULT, M68K_CPU_m68k)
491 (M68K_CPU_m68000, M68K_CPU_m68010, M68K_CPU_m68020, M68K_CPU_m68030)
492 (M68K_CPU_m68040, M68K_CPU_m68302, M68K_CPU_m68332, TARGET_DEFAULT)
493 (ASM_CPU_DEFAULT_SPEC, CC1_CPU_DEFAULT_SPEC): Delete.
494 (ASM_SPEC): Remove use of %(asm_cpu_default).
495 (EXTRA_SPECS, SUBTARGET_EXTRA_SPECS, MULTILIB_DEFAULTS): Delete.
496 * config/m68k/linux.h (TARGET_DEFAULT): Delete.
497 (CPP_SPEC): Merge definitions. Do not handle __HAVE_68881__ here.
498 * config/m68k/netbsd-elf.h (TARGET_OS_CPP_BUILTINS): Define
499 __HAVE_FPU__ if TARGET_HARD_FLOAT.
500 (TARGET_DEFAULT): Delete.
501 (EXTRA_SPECS): Delete cpp_cpu_default_spec, cpp_cpu_spec,
502 cpp_fpu_spec, asm_default_spec and netbsd_cpp_spec.
503 (CPP_CPU_SPEC): Delete.
504 (TARGET_VERSION): Merge definitions, using TARGET_68010 to pick
505 the appropriate string.
506 (CPP_CPU_DEFAULT_SPEC, ASM_DEFAULT_SPEC, CPP_FPU_SPEC): Delete.
507 (CPP_SPEC): Define to NETBSD_CPP_SPEC.
508 (ASM_SPEC): Don't use %(asm_default_spec).
509 * config/m68k/m68k.c (TARGET_DEFAULT_TARGET_FLAGS): Remove
510 TARGET_DEFAULT and add MASK_68881.
511 * config/m68k/m68k.md: Remove mention of TARGET_DEFAULT from comments.
512
513 2007-01-12 Richard Sandiford <richard@codesourcery.com>
514
515 * config.gcc (m68010-*-netbsdelf*): Add MASK_68010.
516 (m68k*-*-netbsdelf*, m68k*-*-openbsd*, m68k*-linux*): Add
517 MASK_68010 alongside MASK_68020.
518 * doc/invoke.texi: Document -m68010.
519 * config/m68k/m68k.opt (m68010): New.
520 * config/m68k/m68k.h (TARGET_CPU_CPP_BUILTINS): Define mc68010
521 if TUNE_68010.
522 (TUNE_68010): New macro.
523 * config/m68k/m68k-none.h (M68K_CPU_m68k, M68K_CPU_m68010)
524 (M68K_CPU_m68020, M68K_CPU_m68030, M68K_CPU_m68040)
525 (M68K_CPU_m68332): Add MASK_68010.
526 * config/m68k/linux.h (TARGET_DEFAULT): Add MASK_68010 to
527 fallback definition.
528 * config/m68k/netbsd-elf.h (CPP_CPU_SPEC): Remove now-redundant
529 defines.
530 * config/m68k/m68k.c (MASK_ALL_CPU_BITS): Add MASK_68010.
531 (m68k_handle_option): Handle OPT_m68010. Add MASK_68010
532 to all entries that use MASK_68020.
533 (output_move_simode_const, output_move_himode, output_move_qimode)
534 (output_move_stricthi, output_move_strictqi): Use TARGET_68010
535 instead of TARGET_68020 to select clr behavior. Remove comment
536 about there being no TARGET_68010.
537 * config/m68k/m68k.md: Likewise throughout.
538
539 2007-01-12 Julian Brown <julian@codesourcery.com>
540
541 * config/m68k/m68k.h (TARGET_ISAB): New macro.
542 * config/m68k/m68k.c: Use TARGET_ISAB rather than TARGET_CFV4.
543 * config/m68k/m68k.md: Likewise.
544
545 2007-01-12 Julian Brown <julian@codesourcery.com>
546
547 * config/m68k/m68k.h (LEGITIMATE_INDEX_P, LEGITIMIZE_ADDRESS): Use
548 TARGET_COLDFIRE_FPU instead of TARGET_CFV4E.
549
550 2007-01-12 Julian Brown <julian@codesourcery.com>
551
552 * config/m68k/m68k.h (TUNE_68040_60): New macro.
553 * config/m68k/m68k.c (standard_68881_constant_p): Use it.
554 * config/m68k/m68k.md: Likewise.
555
556 2007-01-12 Julian Brown <julian@codesourcery.com>
557 Richard Sandiford <richard@codesourcery.com>
558
559 * config/m68k/m68k.h (TARGET_CPU_CPP_BUILTINS): Use TUNE_68030
560 instead of TARGET_68030, TUNE_68040 instead of TARGET_68040,
561 TUNE_68060 instead of TARGET_68060 and TUNE_CPU32 instead of
562 TARGET_CPU32.
563 (TARGET_CPU32): Rename to...
564 (TUNE_CPU32): ...this.
565 (TUNE_68000_10, TUNE_68030, TUNE_68040, TUNE_68060)
566 (TUNE_CFV2): New macros.
567 * config/m68k/netbsd-elf.h (LONG_DOUBLE_TYPE_SIZE): Simplify;
568 remove conditions that are implied by TARGET_68020.
569 * config/m68k/m68k.c (m68k_output_function_prologue): Use TUNE_68040
570 instead of TARGET_68040 and TUNE_CPU32 instead of TARGET_CPU32.
571 (m68k_output_function_epilogue): Likewise.
572 (m68k_rtx_costs): Likewise. Use TUNE_68060 instead of TARGET_68060
573 and TUNE_CFV2 instead of TARGET_5200. Use TUNE_68000_10 instead of
574 "!TARGET_68020 && !TARGET_COLDFIRE" to choose between 68000 and
575 non-68000 timings. Refactor multiplication and division costs.
576 (output_addsi3): Use TUNE_68040 instead of TARGET_68040 and
577 TUNE_CPU32 instead of TARGET_CPU32.
578 (standard_68881_constant_p): Use TUNE_68040 instead of TARGET_68040
579 and TUNE_68060 instead of TARGET_68060.
580 * config/m68k/m68k.md: Use TUNE_68040 instead of TARGET_68040,
581 TUNE_68060 instead of TARGET_68060, and TUNE_CPU32 instead of
582 TARGET_CPU32.
583 (movsi_const0): Use TUNE_68000_10 rather than "!TARGET_68020
584 && !TARGET_COLDFIRE" to choose between moveq and clr.
585 Likewise in the unnamed movsf pattern.
586 (ashlsi_17_24, lshrsi_17_24): Guard with TUNE_68000_10 rather than
587 "!TARGET_68020 && !TARGET_COLDFIRE". Likewise the unnamed
588 ashiftrt pattern.
589
590 2007-01-12 Richard Sandiford <richard@codesourcery.com>
591
592 * config/m68k/m68k.h (TARGET_CPU_CPP_BUILTINS): Increase amount
593 of tabbing before backslashes.
594
595 2007-01-11 John David Anglin <dave.anglin@nrc-cnrc.gc.ca>
596
597 * pa-linux.h (ASM_OUTPUT_INTERNAL_LABEL): Undefine.
598 * pa.h (ASM_OUTPUT_LABEL): Output colon when using GAS.
599 (ASM_OUTPUT_INTERNAL_LABEL): Define.
600
601 2007-01-11 Zdenek Dvorak <dvorakz@suse.cz>
602
603 * tree-ssa-loop-ivopts.c (extract_cond_operands): Split from
604 find_interesting_uses_cond.
605 (find_interesting_uses_cond): Use extract_cond_operands.
606 (rewrite_use_compare): Use extract_cond_operands and
607 force_gimple_operand_bsi. Do not call update_stmt.
608 (determine_use_iv_cost_condition): Use extract_cond_operands.
609 Return cheaper of using original bound and changing the exit bound.
610
611 2007-01-11 Zdenek Dvorak <dvorakz@suse.cz>
612
613 PR tree-optimization/29516
614 * tree-ssa-address.c (tree_mem_ref_addr, add_to_parts,
615 most_expensive_mult_to_index, addr_to_parts,
616 create_mem_ref, maybe_fold_tmr): Make the type of
617 fields of TARGET_MEM_REF sizetype.
618 (move_fixed_address_to_symbol, move_pointer_to_base):
619 New functions.
620 * tree.def (TARGET_MEM_REF): Add comment on types of
621 the operands.
622
623 2007-01-11 Joseph Myers <joseph@codesourcery.com>
624
625 * c-common.c (vector_types_convertible_p): Treat opaque types as
626 always convertible if they have the same size, but not otherwise.
627
628 2007-01-11 Steven Bosscher <steven@gcc.gnu.org>
629
630 * ifcvt.c (struct noce_if_info): Add comments to the fields.
631 Remove the b_unconditional field.
632 (noce_try_sign_mask): Do not look at b_unconditional.
633 (noce_process_if_block): Do not use merge_if_blocks. Update
634 the CFG here. Do not set b_unconditional.
635 (cond_move_process_if_block): Likewise.
636 (find_cond_trap): Likewise.
637 (check_cond_move_block): Require simple jump insns at the end
638 of the basic block.
639
640 2007-01-11 Jan Hubicka <jh@suse.cz>
641
642 PR tree-optimization/1046
643 * tree-tailcall.c (suitable_for_tail_call_opt_p): Use TREE_ADDRESSABLE
644 when alias info is not ready.
645 (pass_tail_recursion): Do not require aliasing.
646 * tree-ssa-copyrename.c (pass_rename_ssa_cop): Likewise.
647 * tree-ssa-ccp.c (pass_ccp, pass_fold_builtins): Likewise.
648 * tree-ssa-copy.c (pass_copy_prop): Likewise.
649 * tree-ssa-forwprop.c (pass_forwprop): Likewise.
650 * tree-ssa-dce.c (pass_dce, pass_dce_loop, pass_cd_dce): Likewise.
651 * passes.c (init_optimization_passes): Execute rename_ssa_copies,
652 ccp, forwprop, copy_prop, merge_phi, copy_prop, dce and tail recursion
653 before inlining.
654 * tree-ssa-operands.c (add_virtual_operand, get_indirect_ref_operand):
655 When aliasing is not build, mark statement as volatile.
656
657 2007-01-11 Tom Tromey <tromey@redhat.com>
658
659 PR preprocessor/15185, PR preprocessor/20989:
660 * doc/cppopts.texi <-MT>: Update description of algorithm for
661 computing default target.
662 <-M, -MD>: Reword "basename" text.
663
664 2007-01-11 Roger Sayle <roger@eyesopen.com>
665
666 * builtins.c (expand_builtin_pow, expand_builtin_powi,
667 fold_builtin_cabs, fold_builtin_sqrt, fold_builtin_trunc,
668 fold_builtin_floor, fold_builtin_ceil, fold_builtin_round,
669 fold_builtin_int_int_roundingfn, fold_builtin_bitop,
670 fold_builtin_bswap, real_constp, fold_builtin_pow,
671 fold_builtin_powi, fold_builtin_signbit, fold_builtin_copysign,
672 do_mpfr_arg1, do_mpfr_arg2, do_mpfr_arg3, do_mpfr_sincos): Replace
673 uses of the macro TREE_CONSTANT_OVERFLOW with TREE_OVERFLOW.
674 * convert.c (convert_to_pointer): Likewise.
675 * expr.c (highest_pow2_factor, expand_expr_real_1): Likewise.
676 * fold-const.c (force_fit_type, fold_negate_expr, int_const_binop,
677 const_binop, fold_convert_const_int_from_int,
678 fold_convert_const_int_from_real,
679 fold_convert_const_real_from_real, sign_bit_p,
680 optimize_minmax_comparison, extract_muldiv_1, fold_div_compare,
681 fold_sign_changed_comparison, fold_unary, fold_comparison,
682 fold_binary, multiple_of_p, tree_Expr_non_zero_p,
683 fold_negate_const, fold_abs_const, fold_not_const): Likewise.
684 * print-tree.c (print_node_brief, print_node): Likewise.
685 * stor-layout.c (place_field, layout_type): Likewise.
686 * tree-chrec.c (keep_cast): Likewise.
687 * tree.c (build_vector, build_real, build_real_from_int_cst,
688 build_complex): Likewise.
689
690 2007-01-11 Roger Sayle <roger@eyesopen.com>
691
692 * tree.h (TREE_CONSTANT_OVERFLOW): Obsolete. For the time being,
693 treat TREE_CONSTANT_OVERFLOW as a synonym of TREE_OVERFLOW.
694
695 2007-01-11 Paolo Bonzini <bonzini@gnu.org>
696
697 * configure.ac (strict1_warn): Rename to strict_warn.
698 (WERROR, --enable-werror, symlink hacks, stage1_cflags,
699 cc_set_by_configure, quoted_cc_set_by_configure,
700 stage_prefix_set_by_configure, quoted_stage_prefix_set_by_configure,
701 all_boot_languages, all_stagestuff): Remove.
702 (target_list): Remove bootstrap targets.
703 * Makefile.in (quickstrap): Unconditionally make a synonym of all.
704 (BOOT_LANGUAGES, STAGE1_CFLAGS, STAGE1_CHECKING,
705 REMAKEFLAGS, FLAGS_TO_PASS, PREPEND_DOTDOT_TO_RELATIVE_PATHS,
706 SUBDIR_FLAGS_TO_PASS, WERROR_FLAGS, STRICT2_WARN, LANG_STAGESTUFF,
707 VOL_FILES, POSTSTAGE1_FLAGS_TO_PASS, STAGE2_FLAGS_TO_PASS,
708 STAGEPROFILE_FLAGS_TO_PASS, STAGEFEEDBACK_FLAGS_TO_PASS, stage1_build,
709 stage1_copy, stage2_build, stage2_copy, stageprofile_build,
710 stageprofile_copy, stage3_build, stage3_copy, stagefeedback_build,
711 stagefeedback_copy, stage4_build, clean_s1, clean_sw, bootstrap,
712 bootstrap-lean, bootstrap2, bootstrap2-lean, bootstrap3,
713 bootstrap3-lean, bootstrap4, bootstrap4-lean, unstage1, unstage2,
714 unstage3, unstage4, unstageprofile, unstagefeedback, restage, restage2,
715 restage3, restage4, restageprofile, restagefeedback, bubbleestrap,
716 cleanstrap, unstrap, restrap, *compare, *compare3, *compare4,
717 *compare-lean, *compare3-lean, *compare4-lean, stage1-start, stage1,
718 stage2-start, stage2, stage3-start, stage3, stage4-start, stage4,
719 stageprofile-start, stageprofile, stagefeedback-start, stagefeedback,
720 risky-stage1, risky-stage2, risky-stage3, risky-stage4): Remove.
721 (ORDINARY_FLAGS_TO_PASS): Rename to FLAGS_TO_PASS.
722 (STAGECOPYSTUFF, STAGEMOVESTUFF): Consolidate into MOSTLYCLEANFILES.
723 (mostlyclean): Adjust.
724 (clean, distclean): Don't mention bootstrap stuff.
725 * configure: Regenerate.
726 * ada/config-lang.in, cp/config-lang.in, forttran/config-lang.in,
727 java/config-lang.in, objc/config-lang.in, objcp/config-lang.in,
728 treelang/config-lang.in (stagestuff): Remove.
729 * doc/sourcebuild.texi (stage1, stage2, stage3, stage4,
730 stageprofile, stagefeedback, stagestuff): Remove mention.
731
732 2007-01-11 Nick Clifton <nickc@redhat.com>
733
734 * config/mcore/predicates.md (mcore_general_movesrc_operand):
735 Accept CONSTs.
736 (mcore_general_movdst_operand): Do not accept CONST_INTs.
737 (mcore_arith_K_S_operand): Run the test for the S constraint not
738 the test for the M constraint.
739 (mcore_addsub_operand): Do not accept integer values that are
740 larger than 32 bits.
741 * config/mcore/mcore.md: Remove unused constraints from split.
742 (andsi3): Use HOST_WIDE_INT instead of int to hold an INTVAL.
743 (addsi3): Likewise.
744 (allocate_stack): Likewise.
745 * config/mcore/mcore.c (mcore_print_operand): Restrict output of P
746 operands to 32 bits.
747 (mcore_const_costs): Use HOST_WIDE_INT instead of int to hold an
748 INTVAL.
749 (mcore_and_cost, mcore_modify_comparison, const_ok_for_mcore,
750 mcore_const_ok_for_inline, mcore_const_trick_uses_not,
751 try_constant_tricks, mcore_num_ones, mcore_num_zeros,
752 mcore_output_bclri, mcore_output_andn, output_inline_const,
753 mcore_output_move, mcore_output_movedouble): Likewise.
754 (mcore_output_cmov): Use CONST_OK_FOR_M and CONST_OK_FOR_N.
755 (output_inline_const): Likewise.
756 (output_inline_const): Fix format strings used in sprintf
757 statements.
758 * config/mcore/mcore-protos.h: Update prototypes for changed
759 functions in mcore.c.
760 * config/mcore/mcore.h (CONST_OK_FOR_I): Cast values to
761 HOST_WIDE_INT and not int.
762 (CONST_OK_FOR_J, CONST_OK_FOR_K, CONST_OK_FOR_L, CONST_OK_FOR_M,
763 CONST_OK_FOR_N): Likewise.
764 (LEGITIMATE_CONSTANT_P): Also check CONSTANT_P.
765 (GO_IF_LEGITIMATE_INDEX): Use HOST_WIDE_INT instead of int to hold
766 an INTVAL.
767
768 2007-01-10 Jan Hubicka <jh@suse.cz>
769
770 * tree-vrp.c (remove_range_assertions): Release defs.
771 * tree-ssa-loop-ivopts.c (rmeove_statement): Likewise.
772 * tree-ssa-dom.c (remove_stmt_or_phi): Likewise.
773
774 2007-01-10 Paul Brook <paul@codesourcery.com>
775
776 * config/arm/arm.c (arm_rtx_costs_1): Handle mutiply-subtract.
777 * config/arm/arm.md (mulsi3subsi): New insn.
778
779 2007-01-10 Zdenek Dvorak <dvorakz@suse.cz>
780
781 * tree-ssa-loop-manip.c (tree_unroll_loop): Make it a wrapper over ...
782 (tree_transform_and_unroll_loop): New.
783 * tree-flow.h (transform_callback, tree_transform_and_unroll_loop):
784 Declare.
785
786 2007-01-10 Robert Kennedy <jimbob@google.com>
787
788 * fold-const.c (fold_comparison): Fold comparisons like (x *
789 1000 < 0) to (x < 0).
790
791 2007-01-10 Ian Lance Taylor <iant@google.com>
792
793 * tree-pretty-print.c (dump_generic_node): Print parentheses when
794 operands have the same priority.
795
796 2007-01-10 Tom Tromey <tromey@redhat.com>
797
798 * fold-const.c (fold_truthop): Don't check can_use_bit_fields_p.
799 (fold_binary): Likewise.
800 * langhooks.c (lhd_can_use_bit_fields_p): Removed.
801 * langhooks-def.h (lhd_can_use_bit_fields_p): Removed.
802 (LANG_HOOKS_CAN_USE_BIT_FIELDS_P): Removed.
803 (LANG_HOOKS_INITIALIZER): Remove LANG_HOOKS_CAN_USE_BIT_FIELDS_P.
804 * langhooks.h (struct lang_hooks): Removed field
805 'can_use_bit_fields_p'.
806
807 2007-01-10 Ralf Corsépius <ralf.corsepius@rtems.org>
808
809 * config/bfin/t-bfin, config/bfin/t-bfin-elf: Remove GCC_CFLAGS.
810
811 2007-01-10 Razya Ladelsky <razya@il.ibm.com>
812
813 * function.c (get_last_funcdef_no): New function.
814 * function.h (get_last_funcdef_no): Declare.
815 * tree-inline.c (initialize_cfun): Add initialization.
816 (tree_function_versioning): Cleanup.
817
818 2007-01-10 Jan Hubicka <jh@suse.cz>
819
820 * tree-inline.c (setup_one_parameter): Do not propagate into abnormal
821 PHIs.
822
823 2007-01-10 Sa Liu <saliu@de.ibm.com>
824 Ben Elliston <bje@au.ibm.com>
825
826 * spu.h (STACK_SAVE_AREA): Use VOIDmode for SAVE_FUNCTION, SImode
827 for SAVE_NONLOCAL and Pmode for any other save level.
828 * spu-protos.h (spu_restore_stack_block): Declare.
829 * spu.md (save_stack_block): Remove.
830 (restore_stack_block): Call spu_restore_stack_block.
831 * spu.c (spu_restore_stack_block): New function.
832 (spu_expand_epilogue): Remove old comment.
833
834 2007-01-09 Zdenek Dvorak <dvorakz@suse.cz>
835
836 PR tree-optimization/30322
837 * tree-ssa-loop-ivopts.c (fold_affine_expr, iv_value): Removed.
838 (cand_value_at): Return the value as aff_tree.
839 (may_eliminate_iv): Convert the bound from aff_tree to tree.
840 * tree-affine.c (aff_combination_add_cst, aff_combination_add_product,
841 aff_combination_mult): New functions.
842 (aff_combination_add): Use aff_combination_add_cst.
843 (aff_combination_convert): Allow conversions to a wider type.
844 (tree_to_aff_combination): Handle BIT_NOT_EXPR.
845 * tree-affine.h (aff_combination_mult): Declare.
846
847 2007-01-09 Carlos O'Donell <carlos@codesourcery.com>
848
849 * doc/tm.texi: Update documentation to reflect reality of exec
850 and start file search behaviours. Update copyright year.
851 * doc/invoke.texi: Explain how GCC_EXEC_PREFIX is used to find
852 header file directories.
853
854 2007-01-09 Uros Bizjak <ubizjak@gmail.com>
855
856 * config/i386/i386.md (*sinxf2): Rename to *sinxf2_i387.
857 (*cosxf2): Rename to cosxf2_i387.
858 (*sindf2, *sinsf2): Extend operand 1 to XFmode. Macroize patterns
859 using X87MODEF12 mode macro. Rename patterns to
860 *sin_extend<mode>xf2_i387. Use SSE_FLOAT_MODE_P to disable patterns
861 for SSE math.
862 (*cosdf2, *cossf2): Ditto.
863 (sincosdf3, sincossf3): Ditto. Rewrite corresponding splitters
864 to match extended input operands.
865 (sincos<mode>3): New expander.
866 (*sinextendsfdf2, *cosextendsfdf2, *sincosextendsfdf3): Remove
867 insn patterns and corresponding splitters.
868
869 2007-01-09 Kaz Kojima <kkojima@gcc.gnu.org>
870
871 * config/sh/t-linux (TARGET_LIBGCC2_CFLAGS): Delete.
872 (SHLIB_MAPFILES, SHLIB_LINK, SHLIB_INSTALL): Likewise.
873
874 2007-01-09 Nicolas Pitre <nico@cam.org>
875
876 PR target/30173
877 * arm/ieee754-df.S (Lad_s): Also test the low word of X for zero.
878
879 2007-01-08 Geoffrey Keating <geoffk@apple.com>
880
881 * target.h (struct gcc_target): New field library_rtti_comdat.
882 * target-def.h (TARGET_CXX_LIBRARY_RTTI_COMDAT): New.
883 (TARGET_CXX): Add TARGET_CXX_LIBRARY_RTTI_COMDAT.
884 * doc/tm.texi (C++ ABI): Document TARGET_CXX_LIBRARY_RTTI_COMDAT.
885 * config/darwin.h (TARGET_CXX_LIBRARY_RTTI_COMDAT): Define.
886
887 2007-01-08 Geoffrey Keating <geoffk@apple.com>
888
889 * doc/invoke.texi (Optimize Options): Correct description of -O0.
890
891 2007-01-08 Richard Guenther <rguenther@suse.de>
892
893 * tree.h (force_fit_type_double): Export.
894 (force_fit_type): Remove.
895 * fold-const.c (force_fit_type_double): New function.
896 (force_fit_type): Remove.
897 (int_const_binop): Use it.
898 (fold_convert_const_int_from_int): Likewise.
899 (fold_convert_const_int_from_real): Likewise.
900 (fold_div_compare): Likewise.
901 (fold_sign_changed_comparison): Likewise.
902 (fold_unary): Likewise.
903 (fold_negate_const): Likewise.
904 (fold_abs_const): Likewise.
905 (fold_not_const): Likewise.
906 * c-common.c (shorten_compare): Use force_fit_type_double.
907 * convert.c (convert_to_pointer): Likewise.
908
909 2007-01-08 Richard Guenther <rguenther@suse.de>
910
911 * tree.h (build_int_cst_wide_type): Export.
912 * tree.c (build_int_cst_wide_type): New function.
913 (build_int_cst_wide): Fix comment.
914 * builtins.c (fold_builtin_object_size): Use build_int_cst
915 to build -1 or 0 of the correct type. Use fit_double_type
916 to check for overflow.
917 * fold-const.c (optimize_bit_field_compare): Use build_int_cst_type
918 to build the mask.
919 (decode_field_reference): Likewise.
920 (all_ones_mask_p): Likewise.
921 (native_interpret_int): Use build_int_cst_wide_type.
922 (fold_binary): Use build_int_cst_type to build an all-ones
923 value.
924 * stor-layout.c (set_sizetype): Use build_int_cst_wide_type.
925
926 2007-01-08 Daniel Jacobowitz <dan@codesourcery.com>
927
928 * config/pa/t-pa64 (libgcc_stub.a): Use $(T).
929
930 2007-01-09 Ben Elliston <bje@au.ibm.com>
931
932 * genautomata.c (STATS_OPTION): New option.
933 (stats_flag): New flag.
934 (gen_automata_option): Handle it.
935 (initiate_automaton_gen): Ditto.
936 (write_automata): Output statistics only if stats_flag is
937 set. Likewise, output time statistics only if time_flag is set.
938 * doc/md.texi (Processor pipeline description): Document new flag.
939
940 2007-01-08 Richard Guenther <rguenther@suse.de>
941
942 * builtins.c (fold_builtin_int_roundingfn): Use fit_double_type.
943 * tree.c (build_int_cst_type): Likewise.
944 (size_in_bytes): Don't call force_fit_type on the result.
945 (int_fits_type_p): Use fit_double_type.
946 * fold-const.c (fit_double_type): New function.
947 (force_fit_type): Use it.
948 * tree.h (fit_double_type): Export.
949
950 2007-01-08 Jan Hubicka <jh@suse.cz>
951
952 * tree-vectorizer.c (gate_increase_alignment): Fix return type.
953 * ipa.c (function_and_variable_visibility): Fix return type.
954
955 2007-01-08 Richard Guenther <rguenther@suse.de>
956
957 * tree-ssa-ccp.c (maybe_fold_offset_to_array_ref): Use type
958 of offset to build the index.
959 * tree-pretty-print.c (dump_generic_node): Don't build negated
960 const just for printing.
961 * c-pretty-print.c (pp_c_integer_constant): Likewise.
962 * builtins.c (fold_builtin_int_roundingfn): Check if result
963 fits the type by using force_fit_type and comparing the result.
964 * predict.c (predict_loops): Use compare_tree_int for comparison.
965 * tree.c (build_int_cst): Fall back to integer_type_node for
966 NULL_TREE type.
967 (build_int_cst_wide): Assert type is non-null.
968
969 2007-01-08 Roberto Costa <roberto.costa@st.com>
970
971 * tree-vrp.c (extract_range_from_cond_expr): New.
972 (extract_range_from_expr): Handle COND_EXPR nodes used as expressions.
973 * tree-ssa-ccp.c (get_maxval_strlen): Handle COND_EXPR nodes used
974 as expressions.
975 (fold_stmt): Bug fix, avoid infinite recursion when folding COND_EXPRs.
976 * tree-ssa-forwprop.c (simplify_cond, forward_propagate_into_cond,
977 tree_ssa_forward_propagate_single_use_vars): Handle COND_EXPR nodes
978 used as expressions.
979 * tree-object-size.c (cond_expr_object_size): New.
980 (collect_object_sizes_for): Handle COND_EXPR nodes used as expressions.
981
982 2007-01-08 Jan Hubicka <jh@suse.cz>
983
984 * tree-ssa-forwprop.c (forward_propagate_into_cond,
985 tree_ssa_forward_propagate_single_use_va): Release defs of propagated
986 statement.
987
988 2007-01-08 Richard Guenther <rguenther@suse.de>
989
990 PR tree-optimization/23603
991 * tree-vrp.c (set_value_range_to_truthvalue): New function.
992 (extract_range_from_binary): Fall back to truthvalue instead of
993 varying for TRUTH_*_EXPR.
994 (extract_range_from_comparison): Fall back to truthvalue instead of
995 varying.
996 (vrp_visit_phi_node): Don't adjust new range bounds to +INF/-INF
997 if all visited PHI values were constant.
998
999 2007-01-08 Jan Hubicka <jh@suse.cz>
1000
1001 * cgraphunit.c (cgraph_process_new_functions): Reset reachable flag.
1002 (cgraph_analyze_function): break out from ...
1003 (cgraph_finalize_compilation_unit): ... here.
1004 (cgraph_expand_function): Remove forgoten commented out line.
1005 (cgraph_optimize): Analyze functions.
1006
1007 2007-01-08 Jan Hubicka <jh@suse.cz>
1008
1009 * tree-pas.h (TODO_remove_function): New flag.
1010 (TODO_update*): Renumber.
1011 (pass_ipa_increase_alignment,
1012 pass_ipa_function_and_variable_visibility): New passes.
1013 * cgraphunit.c (cgraph_increase_alignment): Move to tree-vectorizer.c
1014 (cgraph_function_and_variable_visibility): Move to ipa.c
1015 (cgraph_optimize): Don't call cgraph_function_and_variable_visibility,
1016 cgraph_increase_alignment.
1017 * ipa-inline.c (cgraph_decide_inlining): Don't push timevar.
1018 (cgraph_decide_inlining_incrementally): Push TV_INTEGRATION before
1019 calling tree-inline.
1020 (cgraph_early_inlining): Do not call cgraph_remove_unreachable_nodes.
1021 (pass_ipa_inline, pass_early_ipa_inlining): Set TODO_remove_functions
1022 * tree-vectorizer.c (increase_alignment): Move here from cgraphunit.c
1023 (gate_increase_alignment): New function.
1024 (pass_ipa_increase_alignment): New pass.
1025 * ipa.c: Inline tree-pass.h and timevar.h
1026 (function_and_variable_visibility): Move here from cgraphunit.c
1027 * tree-optimize.c (pass_early_local_passes): Add TODO_remove_functions.
1028 * passes.c (init_optimization_passes): Add the two new passes.
1029 (execute_todo): Handle cgraph_remove_functions.
1030
1031 2007-01-08 Nick Clifton <nickc@redhat.com>
1032
1033 * config/frv/predicates.md (reg_or_0_operand): Accept
1034 CONST_DOUBLEs.
1035
1036 2007-01-08 Ralf Corsépius <ralf.corsepius@rtems.org>
1037
1038 * config/bfin/rtems.h, config/bfin/t-rtems: New.
1039 * config.gcc: Add bfin*-rtems*.
1040
1041 2007-01-08 Mark Shinwell <shinwell@codesourcery.com>
1042
1043 * c.opt: Add -flax-vector-conversions.
1044 * c-typeck.c (convert_for_assignment): Pass flag to
1045 vector_types_convertible_p to allow emission of note.
1046 (digest_init): Likewise.
1047 * c-opts.c: Handle -flax-vector-conversions.
1048 * c-common.c (flag_lax_vector_conversions): New.
1049 (vector_types_convertible_p): Unless -flax-vector conversions
1050 has been passed, disallow conversions between vectors with
1051 differing numbers of subparts and/or element types. If such
1052 a conversion is disallowed, possibly emit a note on the first
1053 occasion only to inform the user of -flax-vector-conversions.
1054 The new last argument specifies this.
1055 * c-common.h (flag_lax_vector_conversions): New.
1056 (vector_types_convertible_p): Add extra argument.
1057 * config/i386/i386.c (ix86_init_mmx_sse_builtins): Use
1058 char_type_node for V*QI type vectors.
1059 * config/rs6000/rs6000-c.c (altivec_overloaded_builtins):
1060 Update to satisfy new typechecking rules.
1061 * config/rs6000/altivec.h (vec_cmple): Use vec_cmpge, for both
1062 C and C++ variants.
1063 * doc/invoke.texi (C Dialect Options): Document
1064 -flax-vector-conversions.
1065
1066 2007-01-08 Mark Shinwell <shinwell@codesourcery.com>
1067
1068 PR tree-optimization/29877
1069 * tree-ssa-ter.c (is_replaceable_p): Deem assignments with
1070 a register variable on the RHS to not be replaceable.
1071
1072 2007-01-08 Chen Liqin <liqin@sunnorth.com.cn>
1073 * config/score/t-score-elf (MULTILIB_OPTIONS): Change.
1074 * config/score/predicates.md (const_uimm5, sr0_operand, const_simm12,
1075 const_simm15, const_pow2, const_npow2): Added.
1076 * config/score/misc.md (insv, extv, extzv, movmemsi,
1077 move_lbu_a/b, mov_lhu_a/b etc): Added and fix some bug.
1078 * config/score/score.c (score_address_cost, score_select_cc_mode):
1079 Added.
1080 Change CONST_OK_FOR_LETTER_P/EXTRA_CONSTRAINT define.
1081 Update score_rtx_costs for MACRO TARGET_RTX_COSTS.
1082 Update score_print_operand.
1083 * config/score/score.h (DATA_ALIGNMENT, SELECT_CC_MODE): Added.
1084 Adjust register allocate order and update some macro define.
1085 * config/score/score-mdaux.c (mdx_unaligned_load, mdx_unsigned_store,
1086 mdx_block_move_straight, mdx_block_move_loop_head,
1087 mdx_block_move_loop_body, mdx_block_move_loop_foot, mdx_block_move_loop,
1088 mdx_block_move): Added.
1089 (mdx_movsicc, mdp_select_add_imm, mdp_select, mds_zero_extract_andi,
1090 mdp_limm): Updated and fix some bug and typo.
1091 * config/score/score.md (movqi/hi/si, add/sub/zero/ext): Updated.
1092 (movsf, movdf, doloop_end): Added.
1093
1094 2007-01-08 Kazu Hirata <kazu@codesourcery.com>
1095
1096 * config/arm/arm.c, config/arm/arm.h, config/arm/arm.md,
1097 config/arm/thumb2.md: Fix comment typos.
1098 * doc/extend.texi: Fix a typo.
1099
1100 2007-01-07 Eric Christopher <echristo@apple.com>
1101
1102 * configure.ac: Check for __stack_chk_fail for darwin.
1103 * configure: Regenerate.
1104
1105 2007-01-07 Richard Guenther <rguenther@suse.de>
1106
1107 * tree-vrp.c (extract_range_from_assert): CSE calls to
1108 compare_values where possible.
1109 (extract_range_from_unary_expr): Likewise.
1110
1111 2007-01-07 Anatoly Sokolov <aesok@post.ru>
1112
1113 * config/avr/avr-protos.h (call_insn_operand): Delete prototype.
1114 * config/avr/avr.c (call_insn_operand): Delete function.
1115 * config/avr/avr.md (*pushqi, *pushhi, *pushsi, *pushsf): Use REG_SP
1116 instead of register number. Use predicates.
1117 * config/avr/predicates.md (const0_operand, reg_or_0_operand,
1118 call_insn_operand): Add.
1119
1120 2007-01-06 Jan Hubicka <jh@suse.cz>
1121
1122 * tree-pass.h (pass_build_cgraph_edges): Declare.
1123 * cgraphunit.c (record_refernece): Move to cgraphbuild.c
1124 (visited_nodes): Remove.
1125 (cgraph_create_edges): Move to cgraphbuild.c; rename to
1126 build_cgrpah_edges; make visited_nodes local.
1127 (cgraph_process_new_functions): DO not call initialize_inline_failed.
1128 (record_references_in_initializer): Move to cgraphbuild.c
1129 (initialize_inline_failed, rebuild_cgraph_edges,
1130 pass_rebuild_cgraph_edges): Move to cgraphbuild.c.
1131 (verify_cgraph_node): Make visited_nodes local.
1132 (cgraph_analyze_function): Do not call cgraph_create_edges and
1133 initialize_inline_failed.
1134 (cgraph_expand_function): Do not call cgraph_lower_function;
1135 assert that function is already lowered.
1136 * Makefile.in (cgraphbuild.o): New.
1137 * passes.c (init_optimization_passes): Add pass_build_cgraph_edges
1138 at the end of lowering passes.
1139
1140 2007-01-06 Steven Bosscher <steven@gcc.gnu.org>
1141
1142 * ifcvt.c (cond_move_convert_if_block): New function, code
1143 factored out from...
1144 (cond_move_process_if_block): ...here. Call the new function
1145 on the THEN and ELSE blocks.
1146 (merge_if_block): Do not copy global_live_at_end, merge_blocks
1147 already takes care of this.
1148
1149 2007-01-05 Manuel Lopez-Ibanez <manu@gcc.gnu.org>
1150
1151 PR c/19978
1152 * tree.h (TREE_OVERFLOW_P): New.
1153 * c-typeck.c (parser_build_unary_op): Warn only if result
1154 overflowed and operands did not.
1155 (parser_build_binary_op): Likewise.
1156 (convert_for_assignment): Remove redundant overflow_warning.
1157 * c-common.c (overflow_warning): Don't check or set TREE_OVERFLOW.
1158
1159 2007-01-05 Manuel Lopez-Ibanez <manu@gcc.gnu.org>
1160
1161 * c-typeck.c (store_init_value): Split over two lines to follow
1162 the GNU coding style.
1163
1164 2007-01-05 Benjamin Kosnik <bkoz@redhat.com>
1165
1166 * c-cppbuiltin.c (c_cpp_builtins): __GXX_EXPERIMENTAL_CPP0X__ to
1167 __GXX_EXPERIMENTAL_CXX0X__.
1168 * doc/cpp.texi: Same.
1169
1170 2007-01-05 Richard Guenther <rguenther@suse.de>
1171
1172 PR middle-end/27826
1173 * tree.c (get_narrower): Do not construct COMPONENT_REFs
1174 with mismatched types. Instead explicitly build a
1175 conversion NOP_EXPR.
1176
1177 2007-01-05 Ian Lance Taylor <iant@google.com>
1178
1179 * c-common.c (decl_with_nonnull_addr_p): New function.
1180 (c_common_truthvalue_conversion): Call it.
1181 * c-typeck.c (build_binary_op): Likewise.
1182 * c-common.h (decl_with_nonnull_addr_p): Declare.
1183
1184 2007-01-05 Jakub Jelinek <jakub@redhat.com>
1185
1186 PR c/30360
1187 * libgcc2.c (__divdc3): Compare c and d against 0.0 instead of
1188 denom against 0.0.
1189
1190 2007-01-05 Joel Brobecker <brobecker@adacore.com>
1191
1192 * doc/install.texi (Final install): Document the fact that
1193 the GNAT runtime should not be stripped.
1194
1195 2007-01-04 Jan Hubicka <jh@suse.cz>
1196
1197 * tree-inline.c (fold_marked_statements): Update operand caches
1198 and EH after folding
1199
1200 2007-01-04 Ian Lance Taylor <iant@google.com>
1201
1202 * c-common.c (check_function_nonnull): Whitespace fix.
1203
1204 2007-01-04 Jan Hubicka <jh@suse.cz>
1205
1206 * tree-optimize.c (execute_fixup_cfg): Correct previously mistakely
1207 comitted older version of patch.
1208 (pass_fixup_cfg): Add TODOs to verify flow and statements, dump
1209 function, celanup cfg and collect garbage.
1210
1211 2007-01-04 Mike Stump <mrs@apple.com>
1212
1213 * Makefile.in (mostlyclean): Don't remove libgcc anymore.
1214 (clean): Likewise.
1215
1216 2007-01-04 Eric Christopher <echristo@apple.com>
1217
1218 * libgcc2.c (__bswapsi2): Use SItype.
1219 (__bswapdi2): Use DItype.
1220 * libgcc2.h: Update for above.
1221
1222 2007-01-04 Paul Brook <paul@codesourcery.com>
1223
1224 * config/arm/arm.md (arm_mulsi3, thumb_mulsi3, mulsi3_compare0,
1225 mulsi_compare0_scratch, mulsi3addsi, mulsi3addsi_compare0,
1226 mulsi3addsi_compare0_scratch, mulsidi3adddi, mulsidi3,
1227 umulsidi3, umulsidi3adddi, smulsi3_highpart,
1228 umulsi3_highpart): Make conditional on !arm_arch6.
1229 (arm_mulsi3_v6, thumb_mulsi3_v6, mulsi3_compare0_v6,
1230 mulsi_compare0_scratch_v6, mulsi3addsi_v6, mulsi3addsi_compare0_v6,
1231 mulsi3addsi_compare0_scratch_v6, mulsidi3adddi_v6, mulsidi3_v6,
1232 umulsidi3_v6, umulsidi3adddi_v6, smulsi3_highpart_v6,
1233 umulsi3_highpart_v6): New insns.
1234
1235 2007-01-04 Roger Sayle <roger@eyesopen.com>
1236
1237 * fold-const.c (fold_convert): When casting an expression to void,
1238 fold_ignored_result may discover a GIMPLE_MODIFY_STMT which doesn't
1239 have a type. Instead of attempting to build a NOP_EXPR, return
1240 these "special" trees directly.
1241
1242 2007-01-04 Joseph Myers <joseph@codesourcery.com>
1243
1244 * config/rs6000/rs6000.c (rs6000_rtx_costs): Make adjustment for
1245 MULT inside MINUS as either argument. Use rs6000_cost->dmul -
1246 rs6000_cost->fp not 0 as adjustment for outer NEG.
1247
1248 2007-01-04 Jan Hubicka <jh@suse.cz>
1249
1250 * cgraph.c (cgraph_release_function_body): New function.
1251 (cgraph_remove_node): Use it.
1252 * cgraph.h (cgraph_release_function_body): Declare.
1253 * cgraphunit.c (cgraph_expand_function): Use it.
1254 * ipa.c (cgraph_remove_unreahchable_nodes): Use it.
1255 * tree-ssa.c (delete_tree_ssa): Allow to be called before aliasing
1256 is initialized and while compilation of other function is running.
1257 * tree-optimize.c (execute_free_cfg_annotations): Move code to clear
1258 statement CFG annotations from here to ...
1259 * tree-cfg.c (delete_tree_cfg_annotations): ... here.
1260
1261 2007-01-04 Zdenek Dvorak <dvorakz@suse.cz>
1262
1263 * cfgloop.h (enum li_flags): Make the constants powers of two.
1264
1265 2007-01-04 Jan Hubicka <jh@suse.cz>
1266
1267 * tree-inline.c (copy_bb): Insert new statements to statements_to_fold
1268 set.
1269 (fold_marked_statements): New function.
1270 (optimize_inline_calls, tree_function_versioning): Fold new statements.
1271 * tree-inline.h (copy_body_data): Add statements_to_fold.
1272
1273 2007-01-03 Daniel Jacobowitz <dan@codesourcery.com>
1274
1275 * config.gcc: Mention libgcc/config.host.
1276 * Makefile.in: Update comments mentioning libgcc.
1277 (LIBGCC, INSTALL_LIBGCC, GCC_PARTS, mklibgcc): Delete.
1278 (all.cross, start.encap, rest.encap, rest.cross): Update
1279 dependencies for libgcc move.
1280 (libgcc.mk, LIBGCC_DEPS, libgcov.a, libgcc.a, stmp-multilib)
1281 (clean-target, clean-target-libgcc): Delete.
1282 (srcdirify, GCC_EXTRA_PARTS): New macros.
1283 (libgcc-support, libgcc.mvars): New rules.
1284 (distclean): Remove mention of mklibgcc.
1285 (install): Don't reference INSTALL_LIBGCC.
1286 (install-common): Don't reference EXTRA_PARTS.
1287 (install-libgcc, install-multilib): Delete rules.
1288 * mklibgcc.in: Delete file.
1289 * doc/configfiles.texi: Don't mention mklibgcc.
1290
1291 * config/i386/t-darwin (SHLIB_VERPFX): Delete (moved to libgcc).
1292 * config/i386/t-darwin64 (SHLIB_VERPFX): Likewise.
1293 * config/rs6000/t-darwin (SHLIB_VERPFX): Likewise.
1294 * config/rs6000/t-ppccomm (TARGET_LIBGCC2_CFLAGS, SHLIB_MAPFILES)
1295 (mklibgcc, ldblspecs): Likewise.
1296
1297 * config/i386/t-nwld (libgcc.def, libc.def, libpcre.def)
1298 (posixpre.def): Use $(T).
1299 (SHLIB_EXT, SHLIB_NAME, SHLIB_SLIBDIR_QUAL, SHLIB_DEF, SHLIB_MAP)
1300 (SHLIB_SRC, SHLIB_INSTALL): Delete.
1301 (SHLIB_LINK): Make dummy.
1302 * config/t-slibgcc-darwin: Delete contents except for dummy SHLIB_LINK.
1303
1304 * config/frv/t-linux (EXTRA_MULTILIB_PARTS): Clear.
1305
1306 * config/alpha/t-crtfm: Use $(T) in rules for EXTRA_PARTS.
1307 * config/alpha/t-vms, config/alpha/t-vms64, config/fr30/t-fr30,
1308 config/i386/t-rtems-i386, config/ia64/t-ia64, config/rs6000/t-beos,
1309 config/rs6000/t-newas, config/sparc/t-elf: Likewise.
1310
1311 * configure.ac (all_outputs): Remove mklibgcc.
1312 * configure: Regenerated.
1313
1314 2007-01-03 Josh Conner <jconner@apple.com>
1315
1316 PR middle-end/29683
1317 * calls.c (compute_argument_addresses): Set stack and stack_slot
1318 for partial args, too.
1319 (store_one_arg): Use locate.size.constant for the size when
1320 generating a save_area.
1321
1322 2007-01-03 Robert Kennedy <jimbob@google.com>
1323
1324 * tree-cfg.c (tree_merge_blocks): Release SSA_NAME phi results
1325 whose definitions are deleted due to basic block merging.
1326
1327 2007-01-03 Paul Brook <paul@codesourcery.com>
1328
1329 PR target/16634
1330 * config/arm/arm.c (output_return_instruction): Pop PC in interrupt
1331 functions.
1332 (use_return_insn): Return 0 for Thumb interrupt functions.
1333 (print_multi_reg): Add rfe argument for IRQ returns.
1334 (arm_output_epilogue): Pop interrupt return address directly into PC.
1335 (arm_expand_prologue): Only adjust IRQ return address in Arm mode.
1336
1337 2007-01-03 Paul Brook <paul@codesourcery.com>
1338
1339 Merge from sourcerygxx-4_1.
1340 * config/arm/thumb2.md: New file.
1341 * config/arm/elf.h (JUMP_TABLES_IN_TEXT_SECTION): Return True for
1342 Thumb-2.
1343 * config/arm/coff.h (JUMP_TABLES_IN_TEXT_SECTION): Ditto.
1344 * config/arm/aout.h (ASM_OUTPUT_ADDR_VEC_ELT): Add !Thumb-2 assertion.
1345 (ASM_OUTPUT_ADDR_DIFF_ELT): Output Thumb-2 jump tables.
1346 * config/arm/aof.h (ASM_OUTPUT_ADDR_DIFF_ELT): Output Thumb-2 jump
1347 tables.
1348 (ASM_OUTPUT_ADDR_VEC_ELT): Add !Thumb-2 assertion.
1349 * config/arm/ieee754-df.S: Use macros for Thumb-2/Unified asm
1350 comptibility.
1351 * config/arm/ieee754-sf.S: Ditto.
1352 * config/arm/arm.c (thumb_base_register_rtx_p): Rename...
1353 (thumb1_base_register_rtx_p): ... to this.
1354 (thumb_index_register_rtx_p): Rename...
1355 (thumb1_index_register_rtx_p): ... to this.
1356 (thumb_output_function_prologue): Rename...
1357 (thumb1_output_function_prologue): ... to this.
1358 (thumb_legitimate_address_p): Rename...
1359 (thumb1_legitimate_address_p): ... to this.
1360 (thumb_rtx_costs): Rename...
1361 (thumb1_rtx_costs): ... to this.
1362 (thumb_compute_save_reg_mask): Rename...
1363 (thumb1_compute_save_reg_mask): ... to this.
1364 (thumb_final_prescan_insn): Rename...
1365 (thumb1_final_prescan_insn): ... to this.
1366 (thumb_expand_epilogue): Rename...
1367 (thumb1_expand_epilogue): ... to this.
1368 (arm_unwind_emit_stm): Rename...
1369 (arm_unwind_emit_sequence): ... to this.
1370 (thumb2_legitimate_index_p, thumb2_legitimate_address_p,
1371 thumb1_compute_save_reg_mask, arm_dwarf_handle_frame_unspec,
1372 thumb2_index_mul_operand, output_move_vfp, arm_shift_nmem,
1373 arm_save_coproc_regs, thumb_set_frame_pointer, arm_print_condition,
1374 thumb2_final_prescan_insn, thumb2_asm_output_opcode, arm_output_shift,
1375 thumb2_output_casesi): New functions.
1376 (TARGET_DWARF_HANDLE_FRAME_UNSPEC): Define.
1377 (FL_THUMB2, FL_NOTM, FL_DIV, FL_FOR_ARCH6T2, FL_FOR_ARCH7,
1378 FL_FOR_ARCH7A, FL_FOR_ARCH7R, FL_FOR_ARCH7M, ARM_LSL_NAME,
1379 THUMB2_WORK_REGS): Define.
1380 (arm_arch_notm, arm_arch_thumb2, arm_arch_hwdiv, arm_condexec_count,
1381 arm_condexec_mask, arm_condexec_masklen)): New variables.
1382 (all_architectures): Add armv6t2, armv7, armv7a, armv7r and armv7m.
1383 (arm_override_options): Check new CPU capabilities.
1384 Set new architecture flag variables.
1385 (arm_isr_value): Handle v7m interrupt functions.
1386 (user_return_insn): Return 0 for v7m interrupt functions. Handle
1387 Thumb-2.
1388 (const_ok_for_arm): Handle Thumb-2 constants.
1389 (arm_gen_constant): Ditto. Use movw when available.
1390 (arm_function_ok_for_sibcall): Return false for v7m interrupt
1391 functions.
1392 (legitimize_pic_address, arm_call_tls_get_addr): Handle Thumb-2.
1393 (thumb_find_work_register, arm_load_pic_register,
1394 legitimize_tls_address, arm_address_cost, load_multiple_sequence,
1395 emit_ldm_seq, emit_stm_seq, arm_select_cc_mode, get_jump_table_size,
1396 print_multi_reg, output_mov_long_double_fpa_from_arm,
1397 output_mov_long_double_arm_from_fpa, output_mov_double_fpa_from_arm,
1398 output_mov_double_fpa_from_arm, output_move_double,
1399 arm_compute_save_reg_mask, arm_compute_save_reg0_reg12_mask,
1400 output_return_instruction, arm_output_function_prologue,
1401 arm_output_epilogue, arm_get_frame_offsets, arm_regno_class,
1402 arm_output_mi_thunk, thumb_set_return_address): Ditto.
1403 (arm_expand_prologue): Handle Thumb-2. Use arm_save_coproc_regs.
1404 (arm_coproc_mem_operand): Allow POST_INC/PRE_DEC.
1405 (arithmetic_instr, shift_op): Use arm_shift_nmem.
1406 (arm_print_operand): Use arm_print_condition. Handle '(', ')', '.',
1407 '!' and 'L'.
1408 (arm_final_prescan_insn): Use extract_constrain_insn_cached.
1409 (thumb_expand_prologue): Use thumb_set_frame_pointer.
1410 (arm_file_start): Output directive for unified syntax.
1411 (arm_unwind_emit_set): Handle stack alignment instruction.
1412 * config/arm/lib1funcs.asm: Remove default for __ARM_ARCH__.
1413 Add v6t2, v7, v7a, v7r and v7m.
1414 (RETLDM): Add Thumb-2 code.
1415 (do_it, shift1, do_push, do_pop, COND, THUMB_SYNTAX): New macros.
1416 * config/arm/arm.h (TARGET_CPU_CPP_BUILTINS): Define __thumb2__.
1417 (TARGET_THUMB1, TARGET_32BIT, TARGET_THUMB2, TARGET_DSP_MULTIPLY,
1418 TARGET_INT_SIMD, TARGET_UNIFIED_ASM, ARM_FT_STACKALIGN, IS_STACKALIGN,
1419 THUMB2_TRAMPOLINE_TEMPLATE, TRAMPOLINE_ADJUST_ADDRESS,
1420 ASM_OUTPUT_OPCODE, THUMB2_GO_IF_LEGITIMATE_ADDRESS,
1421 THUMB2_LEGITIMIZE_ADDRESS, CASE_VECTOR_PC_RELATIVE,
1422 CASE_VECTOR_SHORTEN_MODE, ADDR_VEC_ALIGN, ASM_OUTPUT_CASE_END,
1423 ADJUST_INSN_LENGTH): Define.
1424 (TARGET_REALLY_IWMMXT, TARGET_IWMMXT_ABI, CONDITIONAL_REGISTER_USAGE,
1425 STATIC_CHAIN_REGNUM, HARD_REGNO_NREGS, INDEX_REG_CLASS,
1426 BASE_REG_CLASS, MODE_BASE_REG_CLASS, SMALL_REGISTER_CLASSES,
1427 PREFERRED_RELOAD_CLASS, SECONDARY_OUTPUT_RELOAD_CLASS,
1428 SECONDARY_INPUT_RELOAD_CLASS, LIBCALL_VALUE, FUNCTION_VALUE_REGNO_P,
1429 TRAMPOLINE_SIZE, INITIALIZE_TRAMPOLINE, HAVE_PRE_INCREMENT,
1430 HAVE_POST_DECREMENT, HAVE_PRE_DECREMENT, HAVE_PRE_MODIFY_DISP,
1431 HAVE_POST_MODIFY_DISP, HAVE_PRE_MODIFY_REG, HAVE_POST_MODIFY_REG,
1432 REGNO_MODE_OK_FOR_BASE_P, LEGITIMATE_CONSTANT_P,
1433 REG_MODE_OK_FOR_BASE_P, REG_OK_FOR_INDEX_P, GO_IF_LEGITIMATE_ADDRESS,
1434 LEGITIMIZE_ADDRESS, THUMB2_LEGITIMIZE_ADDRESS,
1435 GO_IF_MODE_DEPENDENT_ADDRESS, MEMORY_MOVE_COST, BRANCH_COST,
1436 ASM_APP_OFF, ASM_OUTPUT_CASE_LABEL, ARM_DECLARE_FUNCTION_NAME,
1437 FINAL_PRESCAN_INSN, PRINT_OPERAND_PUNCT_VALID_P,
1438 PRINT_OPERAND_ADDRESS): Adjust for Thumb-2.
1439 (arm_arch_notm, arm_arch_thumb2, arm_arch_hwdiv): New declarations.
1440 * config/arm/arm-cores.def: Add arm1156t2-s, cortex-a8, cortex-r4 and
1441 cortex-m3.
1442 * config/arm/arm-tune.md: Regenerate.
1443 * config/arm/arm-protos.h: Update prototypes.
1444 * config/arm/vfp.md: Enable patterns for Thumb-2.
1445 (arm_movsi_vfp): Add movw alternative. Use output_move_vfp.
1446 (arm_movdi_vfp, movsf_vfp, movdf_vfp): Use output_move_vfp.
1447 (thumb2_movsi_vfp, thumb2_movdi_vfp, thumb2_movsf_vfp,
1448 thumb2_movdf_vfp, thumb2_movsfcc_vfp, thumb2_movdfcc_vfp): New.
1449 * config/arm/libunwind.S: Add Thumb-2 code.
1450 * config/arm/constraints.md: Update include Thumb-2.
1451 * config/arm/ieee754-sf.S: Add Thumb-2/Unified asm support.
1452 * config/arm/ieee754-df.S: Ditto.
1453 * config/arm/bpabi.S: Ditto.
1454 * config/arm/t-arm (MD_INCLUDES): Add thumb2.md.
1455 * config/arm/predicates.md (low_register_operand,
1456 low_reg_or_int_operand, thumb_16bit_operator): New.
1457 (thumb_cmp_operand, thumb_cmpneg_operand): Rename...
1458 (thumb1_cmp_operand, thumb1_cmpneg_operand): ... to this.
1459 * config/arm/t-arm-elf: Add armv7 multilib.
1460 * config/arm/arm.md: Update patterns for Thumb-2 and Unified asm.
1461 Include thumb2.md.
1462 (UNSPEC_STACK_ALIGN, ce_count): New.
1463 (arm_incscc, arm_decscc, arm_umaxsi3, arm_uminsi3,
1464 arm_zero_extendsidi2, arm_zero_extendqidi2): New
1465 insns/expanders.
1466 * config/arm/fpa.md: Update patterns for Thumb-2 and Unified asm.
1467 (thumb2_movsf_fpa, thumb2_movdf_fpa, thumb2_movxf_fpa,
1468 thumb2_movsfcc_fpa, thumb2_movdfcc_fpa): New insns.
1469 * config/arm/cirrus.md: Update patterns for Thumb-2 and Unified asm.
1470 (cirrus_thumb2_movdi, cirrus_thumb2_movsi_insn,
1471 thumb2_cirrus_movsf_hard_insn, thumb2_cirrus_movdf_hard_insn): New
1472 insns.
1473 * doc/extend.texi: Document ARMv7-M interrupt functions.
1474 * doc/invoke.texi: Document Thumb-2 new cores+architectures.
1475
1476 2007-01-03 Jakub Jelinek <jakub@redhat.com>
1477
1478 * unwind-dw2.c (SIGNAL_FRAME_BIT, EXTENDED_CONTEXT_BIT): Define.
1479 (struct _Unwind_Context): Rename args_size to flags, remove
1480 signal_frame field, add a new args_size field and version field.
1481 (_Unwind_IsSignalFrame, _Unwind_SetSignalFrame,
1482 _Unwind_IsExtendedContext): New inline functions.
1483 (_Unwind_GetGR, _Unwind_SetGR, _Unwind_GetGRPtr, _Unwind_SetGRPtr):
1484 Assume by_value array is only present if _Unwind_IsExtendedContext.
1485 (_Unwind_GetIPInfo, execute_cfa_program, uw_frame_state_for): Use
1486 _Unwind_IsSignalFrame.
1487 (__frame_state_for): Initialize context.flags to EXTENDED_CONTEXT_BIT.
1488 (uw_update_context_1): Use _Unwind_SetSignalFrame.
1489 (uw_init_context_1): Initialize context->flags to
1490 EXTENDED_CONTEXT_BIT.
1491 * config/rs6000/linux-unwind.h (frob_update_context): Use
1492 _Unwind_SetSignalFrame.
1493
1494 2007-01-03 Andrew Pinski <andrew_pinski@playstation.sony.com>
1495
1496 PR middle-end/30353
1497 * gimplify.c (gimplify_modify_expr_complex_part): Move below
1498 tree_to_gimple_tuple. Call tree_to_gimple_tuple when we need
1499 the value.
1500
1501 2007-01-03 Kazu Hirata <kazu@codesourcery.com>
1502
1503 * config/i386/i386.h (NON_STACK_REG_P, REGNO_OK_FOR_SIREG_P,
1504 REGNO_OK_FOR_DIREG_P, REWRITE_ADDRESS, ASM_OPERAND_LETTER,
1505 RET, AT_SP): Remove.
1506 * config/i386/i386.md (*sse_prologue_save_insn): Use return
1507 instead of RET.
1508
1509 * alias.c (init_alias_analysis): Use VEC_safe_grow_cleared.
1510 * cfgbuild.c (find_basic_blocks): Likewise.
1511 * cfgrtl.c (rtl_create_basic_block): Likewise.
1512 * function.c (temp_slots_at_level): Likewise.
1513 * reg-stack.c (stack_regs_mentioned): Likewise.
1514 * regclass.c (allocate_reg_info): Likewise.
1515 * tree-cfg.c (init_empty_tree_cfg, build_tree_cfg, create_bb,
1516 set_bb_for_stmt, move_block_to_fn): Likewise.
1517 * tree-complex.c (tree_lower_complex): Likewise.
1518 * vec.h (VEC_safe_grow_cleared): New.
1519
1520 * cgraphunit.c, tree-ssa-alias.c: Fix comment typos.
1521
1522 2007-01-03 Zdenek Dvorak <dvorakz@suse.cz>
1523
1524 * loop-unswitch.c (unswitch_loop): Pass probabilities to loopify.
1525 * tree-ssa-loop-unswitch.c (tree_unswitch_loop): Pass probabilities
1526 to loop_version.
1527 * cfgloopmanip.c (scale_loop_frequencies): Export.
1528 (loopify): Scale the frequencies by prescribed coefficients.
1529 (set_zero_probability): New function.
1530 (duplicate_loop_to_header_edge): Improve updating of frequencies.
1531 (lv_adjust_loop_entry_edge, loop_version): Set probabilities
1532 and frequencies according to arguments.
1533 * tree-ssa-loop-manip.c (tree_unroll_loop): Set probabilities
1534 correctly.
1535 * cfg.c (scale_bbs_frequencies_int): Allow scaling the frequencies up.
1536 * modulo-sched.c (sms_schedule): Set probabilities for entering
1537 versioned loop correctly.
1538 * tree-vect-transform.c (vect_transform_loop): Ditto.
1539 * cfgloop.h (loopify, loop_version): Declaration changed.
1540 (scale_loop_frequencies): Declared.
1541
1542 2007-01-02 Jan Hubicka <jh@suse.cz>
1543
1544 * cgraph.c: Include tree-flow.h
1545 (cgraph_add_new-function): Handle IPA_SSA mode; execute
1546 early_local_passes.
1547 * cgraph.h (enum cgraph_state): Add CGRAPH_STATE_IPA_SSA.
1548 * tree-pass.h (pass_all_early_optimizations): Declare.
1549 * cgraphunit.c (cgraph_process_new_functions): Add IPA_SSA; execute
1550 early_local_passes.
1551 (cgraph_analyze_function): Do early_local_passes.
1552 * tree-mudflap.c (mf_decl_cache_locals, mf_build_check_statement_for):
1553 Do not add referenced vars.
1554 * tree-optimize.c (gate_all_optimizations): Do not execute when not in
1555 SSA form.
1556 (gate_all_early_local_passes): New gate.
1557 (pass_early_local_passes): Use new gate.
1558 (execute_early_local_optimizations): New functions.
1559 (gate_all_early_optimizations): New gate.
1560 (pass_all_early_optimizations): New pass.
1561 (execute_free_datastructures): Free SSA only when initialized.
1562 (gate_init_datastructures): Init only when optimizing.
1563 (tree_lowering_passes): Do early local passes when called late.
1564 * tree-profile.c (do_tree_profiling): Don't profile functions added
1565 late.
1566 (do_early_tree_profiling, pass_early_tree_profile): Kill.
1567 * tree-cfg.c (update_modified_stmts): Do not update when operands are
1568 not active.
1569 * passes.c (init_optimizations_passes): Reorder so we go into SSA
1570 during early_local_passes.
1571 * Makefile.in (cgraph.o): Add dependency on tree-flow.h.
1572
1573
1574 2007-01-02 Carlos O'Donell <carlos@codesourcery.com>
1575
1576 * Makefile.in: Update copyright year.
1577
1578 2007-01-02 Carlos O'Donell <carlos@codesourcery.com>
1579
1580 * Makefile.in: Export GCC_EXEC_PREFIX before calling $(RUNTEST)
1581 in $(lang_checks) and check-consistency targets.
1582
1583 2007-01-02 Jan Hubicka <jh@suse.cz>
1584
1585 * tree-mudflap.c (mf_decl_cache_locals, mf_build_check_statement_for):
1586 Do not add referenced vars.
1587 * tree-cfg.c (update_modified_stmts): Do not update when SSA operands
1588 are not active.
1589 * passes.c (init_optimization_passes): Put mudflap_2 after
1590 free_datastructures.
1591
1592 2007-01-02 Jan Hubicka <jh@suse.cz>
1593
1594 * tree-optimize (execute_fixup_cfg): Set after_inlining flag.
1595 Set NOTHROW flag on call statements proved to be nothrow.
1596 Update statement of local calls so new pure/const functions are
1597 updated. Update_ssa when in ssa form. Mark PHI nodes of nonlocal
1598 goto receivers.
1599 (tree_rest_of_compilation): Register hooks and initialize bitmap
1600 early. Do not set after_inlining flag.
1601
1602 2007-01-02 Steve Ellcey <sje@cup.hp.com>
1603
1604 * sbitmap.c (HOST_BITS_PER_LONG_LONG): Change to
1605 HOST_BITS_PER_LONGLONG
1606
1607 2007-01-02 Manuel Lopez-Ibanez <manu@gcc.gnu.org>
1608
1609 PR c/19977
1610 * c-typeck.c (store_init_value): Don't emit pedantic overflow
1611 warning for non-static initializers.
1612
1613 2007-01-02 Steven Bosscher <steven@gcc.gnu.org>
1614
1615 * config/alpha/alpha.md, arm/arm.c, darwin.c, frv/frv.md,
1616 m32r/m32r.c, m32r/m32r.c, mn10300/mn10300.md, pa/pa.c,
1617 rs6000/rs6000.c, s390/s390.md, sh/sh.md, sparc/sparc.c:
1618 Always use set_unique_reg_note to add REG_EQUAL notes.
1619
1620 2007-01-02 Kazu Hirata <kazu@codesourcery.com>
1621
1622 Revert:
1623 2007-01-02 Kazu Hirata <kazu@codesourcery.com>
1624
1625 * alias.c (init_alias_analysis): Use VEC_safe_grow_cleared.
1626 * cfgbuild.c (find_basic_blocks): Likewise.
1627 * cfgrtl.c (rtl_create_basic_block): Likewise.
1628 * function.c (temp_slots_at_level): Likewise.
1629 * reg-stack.c (stack_regs_mentioned): Likewise.
1630 * regclass.c (allocate_reg_info): Likewise.
1631 * tree-cfg.c (init_empty_tree_cfg, build_tree_cfg, create_bb,
1632 set_bb_for_stmt, move_block_to_fn): Likewise.
1633 * tree-complex.c (tree_lower_complex): Likewise.
1634 * vec.h (VEC_safe_grow_cleared): New.
1635
1636 2007-01-02 Ian Lance Taylor <iant@google.com>
1637
1638 * c-common.c (c_common_truthvalue_conversion): When warning about
1639 using an assignment as a truth value, set TREE_NO_WARNING.
1640
1641 2007-01-02 Manuel Lopez-Ibanez <manu@gcc.gnu.org>
1642
1643 PR middle-end/7651
1644 * c.opt (Wold-style-declaration): New.
1645 * doc/invoke.texi (C-only Warning Options): New.
1646 (Wold-style-declaration): Document it.
1647 (Wextra): Enabled by -Wextra.
1648 * c-opts.c (c_common_post_options): Enabled by -Wextra.
1649 * c-decl.c (declspecs_add_scspec): Replace -Wextra with
1650 -Wold-style-declaration.
1651
1652 2007-01-02 Kazu Hirata <kazu@codesourcery.com>
1653
1654 * alias.c (init_alias_analysis): Use VEC_safe_grow_cleared.
1655 * cfgbuild.c (find_basic_blocks): Likewise.
1656 * cfgrtl.c (rtl_create_basic_block): Likewise.
1657 * function.c (temp_slots_at_level): Likewise.
1658 * reg-stack.c (stack_regs_mentioned): Likewise.
1659 * regclass.c (allocate_reg_info): Likewise.
1660 * tree-cfg.c (init_empty_tree_cfg, build_tree_cfg, create_bb,
1661 set_bb_for_stmt, move_block_to_fn): Likewise.
1662 * tree-complex.c (tree_lower_complex): Likewise.
1663 * vec.h (VEC_safe_grow_cleared): New.
1664
1665 2007-01-02 Douglas Gregor <doug.gregor@gmail.com>
1666
1667 * c-common.c(c_common_nodes_and_builtins): Since variants of
1668 void_type_node get built before it is given a name, we need to
1669 give those variants the name, too.
1670 (complete_array_type): We need to work with the canonical main
1671 type of the array, from which we will build the qualified version.
1672 * params.def (PARAM_VERIFY_CANONICAL_TYPES): New.
1673 * print-tree.c (print_node): Display canonical type information
1674 for each type.
1675 * stor-layout.c (layout_type): When we don't know the
1676 alignment of a type for which we're building an array, we end up
1677 guessing wrong, so make the type require structural equality.
1678 * tree.c (make_node_stat): When we build a new type, it is its
1679 own canonical type.
1680 (build_type_attribute_qual_variant): When building an attribute
1681 variant, its canonical type is the non-attribute variant. However,
1682 if the attributes are target-dependent and they differ, we need to
1683 use structural equality checks for this type.
1684 (build_qualified_type): A qualified type is not equivalent to its
1685 unqualified variant; set the canonical type appropriately.
1686 (build_distinct_type_copy): When building a distinct type from
1687 another type, the new type is its own canonical type.
1688 (build_variant_type_copy): When building a new type variant, we
1689 assume that it is equivalent to the original type.
1690 (build_pointer_type_for_mode): When building a pointer type, also
1691 build a canonical type pointer.
1692 (build_reference_type_for_mode): When building a reference type,
1693 also build a canonical type reference.
1694 (build_index_type): When we can't hash an index type (e.g.,
1695 because its maximum value is negative), the index type requires
1696 structural equality tests.
1697 (build_array_type): Build the canonical form of an array type.
1698 (build_function_type): Function types require structural equality,
1699 because they contain default arguments, attributes, etc.
1700 (build_method_type_directly): Ditto for method types.
1701 (build_offset_type): Build the canonical offset type.
1702 (build_complex_type): Build the canonical vector type.
1703 (make_vector_type): Build the canonical vector type.
1704 * tree.h (TYPE_CANONICAL): New.
1705 (TYPE_STRUCTURAL_EQUALITY_P): New.
1706 (SET_TYPE_STRUCTURAL_EQUALITY): New.
1707 (struct tree_type): Added "canonical" field.
1708 * params.h (VERIFY_CANONICAL_TYPES): New.
1709 * doc/c-tree.texi (TYPE_CANONICAL): Document.
1710 (TYPE_STRUCTURAL_EQUALITY_P): Document.
1711 (SET_TYPE_STRUCTURAL_EQUALITY): Document.
1712 * doc/invoke.texi (verify-canonical-types): Document --param
1713 parameter for verifying canonical types.
1714
1715 2007-01-02 Joseph Myers <joseph@codesourcery.com>
1716
1717 * config.gcc (powerpc-*-eabispe*, powerpc-*-eabisimaltivec*,
1718 powerpc-*-eabisim*, powerpc-*-eabialtivec*, powerpc-*-eabi*,
1719 powerpc-*-rtems*, powerpc-wrs-vxworks, powerpc-wrs-vxworksae,
1720 powerpcle-*-eabisim*, powerpcle-*-eabi*): Add rs6000/e500.h to
1721 tm_file.
1722 * config/rs6000/e500.h: New.
1723 * config/rs6000/eabi.h (TARGET_SPE_ABI, TARGET_SPE, TARGET_E500,
1724 TARGET_ISEL, TARGET_FPRS, TARGET_E500_SINGLE, TARGET_E500_DOUBLE):
1725 Remove.
1726 * config/rs6000/linuxspe.h (TARGET_SPE_ABI, TARGET_SPE,
1727 TARGET_E500, TARGET_ISEL, TARGET_FPRS, TARGET_E500_SINGLE,
1728 TARGET_E500_DOUBLE): Remove.
1729 * config/rs6000/vxworks.h (TARGET_SPE_ABI, TARGET_SPE,
1730 TARGET_E500, TARGET_ISEL, TARGET_FPRS): Remove.
1731 * config/rs6000/rs6000.h (CHECK_E500_OPTIONS): Define.
1732 * config/rs6000/rs6000.c (rs6000_override_options): Use
1733 CHECK_E500_OPTIONS.
1734
1735 2007-01-02 Joseph Myers <joseph@codesourcery.com>
1736
1737 * config/rs6000/rs6000.c (print_operand): Check (TARGET_SPE ||
1738 TARGET_E500_DOUBLE), not TARGET_E500, for %y.
1739 (rs6000_generate_compare, rs6000_emit_sCOND, output_cbranch,
1740 rs6000_emit_cmove): Don't check TARGET_E500.
1741 * config/rs6000/rs6000.md (bunordered, bordered, sunordered,
1742 sordered): Don't check TARGET_E500.
1743
1744 2007-01-01 Eric Christopher <echristo@apple.com>
1745
1746 * config/mips/mips.c (mips_regno_mode_ok_for_base_p): Use
1747 HARD_REGISTER_NUM_P.
1748
1749 2007-01-01 Roger Sayle <roger@eyesopen.com>
1750
1751 * fold-const.c (fold_binary) <EQ_EXPR>: Fold "(X^C1) eq/ne C2" into
1752 "X eq/ne (C1^C2)". Fold "(X^Z) eq/ne (Y^Z)" as "X eq/ne Y" when Z
1753 has no side-effects. Fold "(X^C1) eq/ne (Y^C2)" as "(X^(C1^C2))
1754 eq/ne Y".
1755
1756 2007-01-01 Mike Stump <mrs@apple.com>
1757
1758 * configure.ac: Remove support for building with Apple's gcc-3.1.
1759
1760 2007-01-02 Joseph Myers <joseph@codesourcery.com>
1761
1762 PR middle-end/30311
1763 * caller-save.c (add_stored_regs): Only handle SUBREGs if inner
1764 REG is a hard register. Do not modify REG before calling
1765 subreg_nregs.
1766 * rtlanal.c (subreg_get_info): Don't assert size of XMODE is a
1767 multiple of the size of YMODE for certain lowpart cases.
1768
1769 2007-01-01 Andrew Pinski <pinskia@gmail.com>
1770
1771 PR middle-end/30253
1772 * gimplify (voidify_wrapper_expr): Update for
1773 GIMPLE_MODIFY_STMT.
1774
1775 2007-01-01 Andreas Schwab <schwab@suse.de>
1776
1777 PR target/29166
1778 * config/ia64/ia64.c (ia64_compute_frame_size): Account space for
1779 save of BR0 in extra_spill_size instead of spill_size.
1780 (ia64_expand_prologue): Save BR0 outside of the gr/br/fr spill
1781 area.
1782 (ia64_expand_epilogue): Restore BR0 from its new location.
1783
1784 2007-01-01 Andrew Pinski <pinskia@gmail.com>
1785
1786 * gimplify.c (gimplify_init_constructor <case VECTOR_TYPE>):
1787 Use a temporary variable if the left hand side is not a gimple
1788 register.
1789
1790 2007-01-01 Andrew Pinski <pinskia@gmail.com>
1791
1792 * gimplify.c (gimplify_return_expr): Make the temporary variable
1793 for the return expression, a gimple register variable.
1794
1795 2007-01-01 Jan Hubicka <jh@suse.cz>
1796
1797 * emit-rtl.c (emit_copy_of_insn_after): Do not call copy_insn_1 for
1798 INSN_LIST.
1799
1800 2007-01-01 Mike Stump <mrs@apple.com>
1801
1802 * configure.ac (HAVE_GAS_LITERAL16): Add autoconf check for
1803 .literal16.
1804 * config/darwin.c (machopic_select_rtx_section): Use
1805 HAVE_GAS_LITERAL16.
1806 (darwin_mergeable_constant_section): Likewise.
1807 * configure: Regenerate.
1808 * config.in: Regenerate.
1809
1810 2007-01-01 Jan Hubicka <jh@suse.cz>
1811 Andrew Pinski <pinskia@gmail.com>
1812
1813 * cgraphunit.c (cgraph_optimize): Call cgraph_add_new_functions
1814 before starting IPA passes.