1 2007-01-08 Jan Hubicka <jh@suse.cz>
3 * tree-pas.h (TODO_remove_function): New flag.
4 (TODO_update*): Renumber.
5 (pass_ipa_increase_alignment,
6 pass_ipa_function_and_variable_visibility): New passes.
7 * cgraphunit.c (cgraph_increase_alignment): Move to tree-vectorizer.c
8 (cgraph_function_and_variable_visibility): Move to ipa.c
9 (cgraph_optimize): Don't call cgraph_function_and_variable_visibility,
10 cgraph_increase_alignment.
11 * ipa-inline.c (cgraph_decide_inlining): Don't push timevar.
12 (cgraph_decide_inlining_incrementally): Push TV_INTEGRATION before
14 (cgraph_early_inlining): Do not call cgraph_remove_unreachable_nodes.
15 (pass_ipa_inline, pass_early_ipa_inlining): Set TODO_remove_functions
16 * tree-vectorizer.c (increase_alignment): Move here from cgraphunit.c
17 (gate_increase_alignment): New function.
18 (pass_ipa_increase_alignment): New pass.
19 * ipa.c: Inline tree-pass.h and timevar.h
20 (function_and_variable_visibility): Move here from cgraphunit.c
21 * tree-optimize.c (pass_early_local_passes): Add TODO_remove_functions.
22 * passes.c (init_optimization_passes): Add the two new passes.
23 (execute_todo): Handle cgraph_remove_functions.
25 2007-01-08 Nick Clifton <nickc@redhat.com>
27 * config/frv/predicates.md (reg_or_0_operand): Accept
30 2007-01-08 Ralf Corsépius <ralf.corsepius@rtems.org>
32 * config/bfin/rtems.h, config/bfin/t-rtems: New.
33 * config.gcc: Add bfin*-rtems*.
35 2007-01-08 Mark Shinwell <shinwell@codesourcery.com>
37 * c.opt: Add -flax-vector-conversions.
38 * c-typeck.c (convert_for_assignment): Pass flag to
39 vector_types_convertible_p to allow emission of note.
40 (digest_init): Likewise.
41 * c-opts.c: Handle -flax-vector-conversions.
42 * c-common.c (flag_lax_vector_conversions): New.
43 (vector_types_convertible_p): Unless -flax-vector conversions
44 has been passed, disallow conversions between vectors with
45 differing numbers of subparts and/or element types. If such
46 a conversion is disallowed, possibly emit a note on the first
47 occasion only to inform the user of -flax-vector-conversions.
48 The new last argument specifies this.
49 * c-common.h (flag_lax_vector_conversions): New.
50 (vector_types_convertible_p): Add extra argument.
51 * config/i386/i386.c (ix86_init_mmx_sse_builtins): Use
52 char_type_node for V*QI type vectors.
53 * config/rs6000/rs6000-c.c (altivec_overloaded_builtins):
54 Update to satisfy new typechecking rules.
55 * config/rs6000/altivec.h (vec_cmple): Use vec_cmpge, for both
57 * doc/invoke.texi (C Dialect Options): Document
58 -flax-vector-conversions.
60 2007-01-08 Mark Shinwell <shinwell@codesourcery.com>
62 PR tree-optimization/29877
63 * tree-ssa-ter.c (is_replaceable_p): Deem assignments with
64 a register variable on the RHS to not be replaceable.
66 2007-01-08 Chen Liqin <liqin@sunnorth.com.cn>
67 * config/score/t-score-elf (MULTILIB_OPTIONS): Change.
68 * config/score/predicates.md (const_uimm5, sr0_operand, const_simm12,
69 const_simm15, const_pow2, const_npow2): Added.
70 * config/score/misc.md (insv, extv, extzv, movmemsi,
71 move_lbu_a/b, mov_lhu_a/b etc): Added and fix some bug.
72 * config/score/score.c (score_address_cost, score_select_cc_mode):
74 Change CONST_OK_FOR_LETTER_P/EXTRA_CONSTRAINT define.
75 Update score_rtx_costs for MACRO TARGET_RTX_COSTS.
76 Update score_print_operand.
77 * config/score/score.h (DATA_ALIGNMENT, SELECT_CC_MODE): Added.
78 Adjust register allocate order and update some macro define.
79 * config/score/score-mdaux.c (mdx_unaligned_load, mdx_unsigned_store,
80 mdx_block_move_straight, mdx_block_move_loop_head,
81 mdx_block_move_loop_body, mdx_block_move_loop_foot, mdx_block_move_loop,
82 mdx_block_move): Added.
83 (mdx_movsicc, mdp_select_add_imm, mdp_select, mds_zero_extract_andi,
84 mdp_limm): Updated and fix some bug and typo.
85 * config/score/score.md (movqi/hi/si, add/sub/zero/ext): Updated.
86 (movsf, movdf, doloop_end): Added.
88 2007-01-08 Kazu Hirata <kazu@codesourcery.com>
90 * config/arm/arm.c, config/arm/arm.h, config/arm/arm.md,
91 config/arm/thumb2.md: Fix comment typos.
92 * doc/extend.texi: Fix a typo.
94 2007-01-07 Eric Christopher <echristo@apple.com>
96 * configure.ac: Check for __stack_chk_fail for darwin.
97 * configure: Regenerate.
99 2007-01-07 Richard Guenther <rguenther@suse.de>
101 * tree-vrp.c (extract_range_from_assert): CSE calls to
102 compare_values where possible.
103 (extract_range_from_unary_expr): Likewise.
105 2007-01-07 Anatoly Sokolov <aesok@post.ru>
107 * config/avr/avr-protos.h (call_insn_operand): Delete prototype.
108 * config/avr/avr.c (call_insn_operand): Delete function.
109 * config/avr/avr.md (*pushqi, *pushhi, *pushsi, *pushsf): Use REG_SP
110 instead of register number. Use predicates.
111 * config/avr/predicates.md (const0_operand, reg_or_0_operand,
112 call_insn_operand): Add.
114 2007-01-06 Jan Hubicka <jh@suse.cz>
116 * tree-pass.h (pass_build_cgraph_edges): Declare.
117 * cgraphunit.c (record_refernece): Move to cgraphbuild.c
118 (visited_nodes): Remove.
119 (cgraph_create_edges): Move to cgraphbuild.c; rename to
120 build_cgrpah_edges; make visited_nodes local.
121 (cgraph_process_new_functions): DO not call initialize_inline_failed.
122 (record_references_in_initializer): Move to cgraphbuild.c
123 (initialize_inline_failed, rebuild_cgraph_edges,
124 pass_rebuild_cgraph_edges): Move to cgraphbuild.c.
125 (verify_cgraph_node): Make visited_nodes local.
126 (cgraph_analyze_function): Do not call cgraph_create_edges and
127 initialize_inline_failed.
128 (cgraph_expand_function): Do not call cgraph_lower_function;
129 assert that function is already lowered.
130 * Makefile.in (cgraphbuild.o): New.
131 * passes.c (init_optimization_passes): Add pass_build_cgraph_edges
132 at the end of lowering passes.
134 2007-01-06 Steven Bosscher <steven@gcc.gnu.org>
136 * ifcvt.c (cond_move_convert_if_block): New function, code
138 (cond_move_process_if_block): ...here. Call the new function
139 on the THEN and ELSE blocks.
140 (merge_if_block): Do not copy global_live_at_end, merge_blocks
141 already takes care of this.
143 2007-01-05 Manuel Lopez-Ibanez <manu@gcc.gnu.org>
146 * tree.h (TREE_OVERFLOW_P): New.
147 * c-typeck.c (parser_build_unary_op): Warn only if result
148 overflowed and operands did not.
149 (parser_build_binary_op): Likewise.
150 (convert_for_assignment): Remove redundant overflow_warning.
151 * c-common.c (overflow_warning): Don't check or set TREE_OVERFLOW.
153 2007-01-05 Manuel Lopez-Ibanez <manu@gcc.gnu.org>
155 * c-typeck.c (store_init_value): Split over two lines to follow
156 the GNU coding style.
158 2007-01-05 Benjamin Kosnik <bkoz@redhat.com>
160 * c-cppbuiltin.c (c_cpp_builtins): __GXX_EXPERIMENTAL_CPP0X__ to
161 __GXX_EXPERIMENTAL_CXX0X__.
162 * doc/cpp.texi: Same.
164 2007-01-05 Richard Guenther <rguenther@suse.de>
167 * tree.c (get_narrower): Do not construct COMPONENT_REFs
168 with mismatched types. Instead explicitly build a
171 2007-01-05 Ian Lance Taylor <iant@google.com>
173 * c-common.c (decl_with_nonnull_addr_p): New function.
174 (c_common_truthvalue_conversion): Call it.
175 * c-typeck.c (build_binary_op): Likewise.
176 * c-common.h (decl_with_nonnull_addr_p): Declare.
178 2007-01-05 Jakub Jelinek <jakub@redhat.com>
181 * libgcc2.c (__divdc3): Compare c and d against 0.0 instead of
184 2007-01-05 Joel Brobecker <brobecker@adacore.com>
186 * doc/install.texi (Final install): Document the fact that
187 the GNAT runtime should not be stripped.
189 2007-01-04 Jan Hubicka <jh@suse.cz>
191 * tree-inline.c (fold_marked_statements): Update operand caches
194 2007-01-04 Ian Lance Taylor <iant@google.com>
196 * c-common.c (check_function_nonnull): Whitespace fix.
198 2007-01-04 Jan Hubicka <jh@suse.cz>
200 * tree-optimize.c (execute_fixup_cfg): Correct previously mistakely
201 comitted older version of patch.
202 (pass_fixup_cfg): Add TODOs to verify flow and statements, dump
203 function, celanup cfg and collect garbage.
205 2007-01-04 Mike Stump <mrs@apple.com>
207 * Makefile.in (mostlyclean): Don't remove libgcc anymore.
210 2007-01-04 Eric Christopher <echristo@apple.com>
212 * libgcc2.c (__bswapsi2): Use SItype.
213 (__bswapdi2): Use DItype.
214 * libgcc2.h: Update for above.
216 2007-01-04 Paul Brook <paul@codesourcery.com>
218 * config/arm/arm.md (arm_mulsi3, thumb_mulsi3, mulsi3_compare0,
219 mulsi_compare0_scratch, mulsi3addsi, mulsi3addsi_compare0,
220 mulsi3addsi_compare0_scratch, mulsidi3adddi, mulsidi3,
221 umulsidi3, umulsidi3adddi, smulsi3_highpart,
222 umulsi3_highpart): Make conditional on !arm_arch6.
223 (arm_mulsi3_v6, thumb_mulsi3_v6, mulsi3_compare0_v6,
224 mulsi_compare0_scratch_v6, mulsi3addsi_v6, mulsi3addsi_compare0_v6,
225 mulsi3addsi_compare0_scratch_v6, mulsidi3adddi_v6, mulsidi3_v6,
226 umulsidi3_v6, umulsidi3adddi_v6, smulsi3_highpart_v6,
227 umulsi3_highpart_v6): New insns.
229 2007-01-04 Roger Sayle <roger@eyesopen.com>
231 * fold-const.c (fold_convert): When casting an expression to void,
232 fold_ignored_result may discover a GIMPLE_MODIFY_STMT which doesn't
233 have a type. Instead of attempting to build a NOP_EXPR, return
234 these "special" trees directly.
236 2007-01-04 Joseph Myers <joseph@codesourcery.com>
238 * config/rs6000/rs6000.c (rs6000_rtx_costs): Make adjustment for
239 MULT inside MINUS as either argument. Use rs6000_cost->dmul -
240 rs6000_cost->fp not 0 as adjustment for outer NEG.
242 2007-01-04 Jan Hubicka <jh@suse.cz>
244 * cgraph.c (cgraph_release_function_body): New function.
245 (cgraph_remove_node): Use it.
246 * cgraph.h (cgraph_release_function_body): Declare.
247 * cgraphunit.c (cgraph_expand_function): Use it.
248 * ipa.c (cgraph_remove_unreahchable_nodes): Use it.
249 * tree-ssa.c (delete_tree_ssa): Allow to be called before aliasing
250 is initialized and while compilation of other function is running.
251 * tree-optimize.c (execute_free_cfg_annotations): Move code to clear
252 statement CFG annotations from here to ...
253 * tree-cfg.c (delete_tree_cfg_annotations): ... here.
255 2007-01-04 Zdenek Dvorak <dvorakz@suse.cz>
257 * cfgloop.h (enum li_flags): Make the constants powers of two.
259 2007-01-04 Jan Hubicka <jh@suse.cz>
261 * tree-inline.c (copy_bb): Insert new statements to statements_to_fold
263 (fold_marked_statements): New function.
264 (optimize_inline_calls, tree_function_versioning): Fold new statements.
265 * tree-inline.h (copy_body_data): Add statements_to_fold.
267 2007-01-03 Daniel Jacobowitz <dan@codesourcery.com>
269 * config.gcc: Mention libgcc/config.host.
270 * Makefile.in: Update comments mentioning libgcc.
271 (LIBGCC, INSTALL_LIBGCC, GCC_PARTS, mklibgcc): Delete.
272 (all.cross, start.encap, rest.encap, rest.cross): Update
273 dependencies for libgcc move.
274 (libgcc.mk, LIBGCC_DEPS, libgcov.a, libgcc.a, stmp-multilib)
275 (clean-target, clean-target-libgcc): Delete.
276 (srcdirify, GCC_EXTRA_PARTS): New macros.
277 (libgcc-support, libgcc.mvars): New rules.
278 (distclean): Remove mention of mklibgcc.
279 (install): Don't reference INSTALL_LIBGCC.
280 (install-common): Don't reference EXTRA_PARTS.
281 (install-libgcc, install-multilib): Delete rules.
282 * mklibgcc.in: Delete file.
283 * doc/configfiles.texi: Don't mention mklibgcc.
285 * config/i386/t-darwin (SHLIB_VERPFX): Delete (moved to libgcc).
286 * config/i386/t-darwin64 (SHLIB_VERPFX): Likewise.
287 * config/rs6000/t-darwin (SHLIB_VERPFX): Likewise.
288 * config/rs6000/t-ppccomm (TARGET_LIBGCC2_CFLAGS, SHLIB_MAPFILES)
289 (mklibgcc, ldblspecs): Likewise.
291 * config/i386/t-nwld (libgcc.def, libc.def, libpcre.def)
292 (posixpre.def): Use $(T).
293 (SHLIB_EXT, SHLIB_NAME, SHLIB_SLIBDIR_QUAL, SHLIB_DEF, SHLIB_MAP)
294 (SHLIB_SRC, SHLIB_INSTALL): Delete.
295 (SHLIB_LINK): Make dummy.
296 * config/t-slibgcc-darwin: Delete contents except for dummy SHLIB_LINK.
298 * config/frv/t-linux (EXTRA_MULTILIB_PARTS): Clear.
300 * config/alpha/t-crtfm: Use $(T) in rules for EXTRA_PARTS.
301 * config/alpha/t-vms, config/alpha/t-vms64, config/fr30/t-fr30,
302 config/i386/t-rtems-i386, config/ia64/t-ia64, config/rs6000/t-beos,
303 config/rs6000/t-newas, config/sparc/t-elf: Likewise.
305 * configure.ac (all_outputs): Remove mklibgcc.
306 * configure: Regenerated.
308 2007-01-03 Josh Conner <jconner@apple.com>
311 * calls.c (compute_argument_addresses): Set stack and stack_slot
312 for partial args, too.
313 (store_one_arg): Use locate.size.constant for the size when
314 generating a save_area.
316 2007-01-03 Robert Kennedy <jimbob@google.com>
318 * tree-cfg.c (tree_merge_blocks): Release SSA_NAME phi results
319 whose definitions are deleted due to basic block merging.
321 2007-01-03 Paul Brook <paul@codesourcery.com>
324 * config/arm/arm.c (output_return_instruction): Pop PC in interrupt
326 (use_return_insn): Return 0 for Thumb interrupt functions.
327 (print_multi_reg): Add rfe argument for IRQ returns.
328 (arm_output_epilogue): Pop interrupt return address directly into PC.
329 (arm_expand_prologue): Only adjust IRQ return address in Arm mode.
331 2007-01-03 Paul Brook <paul@codesourcery.com>
333 Merge from sourcerygxx-4_1.
334 * config/arm/thumb2.md: New file.
335 * config/arm/elf.h (JUMP_TABLES_IN_TEXT_SECTION): Return True for
337 * config/arm/coff.h (JUMP_TABLES_IN_TEXT_SECTION): Ditto.
338 * config/arm/aout.h (ASM_OUTPUT_ADDR_VEC_ELT): Add !Thumb-2 assertion.
339 (ASM_OUTPUT_ADDR_DIFF_ELT): Output Thumb-2 jump tables.
340 * config/arm/aof.h (ASM_OUTPUT_ADDR_DIFF_ELT): Output Thumb-2 jump
342 (ASM_OUTPUT_ADDR_VEC_ELT): Add !Thumb-2 assertion.
343 * config/arm/ieee754-df.S: Use macros for Thumb-2/Unified asm
345 * config/arm/ieee754-sf.S: Ditto.
346 * config/arm/arm.c (thumb_base_register_rtx_p): Rename...
347 (thumb1_base_register_rtx_p): ... to this.
348 (thumb_index_register_rtx_p): Rename...
349 (thumb1_index_register_rtx_p): ... to this.
350 (thumb_output_function_prologue): Rename...
351 (thumb1_output_function_prologue): ... to this.
352 (thumb_legitimate_address_p): Rename...
353 (thumb1_legitimate_address_p): ... to this.
354 (thumb_rtx_costs): Rename...
355 (thumb1_rtx_costs): ... to this.
356 (thumb_compute_save_reg_mask): Rename...
357 (thumb1_compute_save_reg_mask): ... to this.
358 (thumb_final_prescan_insn): Rename...
359 (thumb1_final_prescan_insn): ... to this.
360 (thumb_expand_epilogue): Rename...
361 (thumb1_expand_epilogue): ... to this.
362 (arm_unwind_emit_stm): Rename...
363 (arm_unwind_emit_sequence): ... to this.
364 (thumb2_legitimate_index_p, thumb2_legitimate_address_p,
365 thumb1_compute_save_reg_mask, arm_dwarf_handle_frame_unspec,
366 thumb2_index_mul_operand, output_move_vfp, arm_shift_nmem,
367 arm_save_coproc_regs, thumb_set_frame_pointer, arm_print_condition,
368 thumb2_final_prescan_insn, thumb2_asm_output_opcode, arm_output_shift,
369 thumb2_output_casesi): New functions.
370 (TARGET_DWARF_HANDLE_FRAME_UNSPEC): Define.
371 (FL_THUMB2, FL_NOTM, FL_DIV, FL_FOR_ARCH6T2, FL_FOR_ARCH7,
372 FL_FOR_ARCH7A, FL_FOR_ARCH7R, FL_FOR_ARCH7M, ARM_LSL_NAME,
373 THUMB2_WORK_REGS): Define.
374 (arm_arch_notm, arm_arch_thumb2, arm_arch_hwdiv, arm_condexec_count,
375 arm_condexec_mask, arm_condexec_masklen)): New variables.
376 (all_architectures): Add armv6t2, armv7, armv7a, armv7r and armv7m.
377 (arm_override_options): Check new CPU capabilities.
378 Set new architecture flag variables.
379 (arm_isr_value): Handle v7m interrupt functions.
380 (user_return_insn): Return 0 for v7m interrupt functions. Handle
382 (const_ok_for_arm): Handle Thumb-2 constants.
383 (arm_gen_constant): Ditto. Use movw when available.
384 (arm_function_ok_for_sibcall): Return false for v7m interrupt
386 (legitimize_pic_address, arm_call_tls_get_addr): Handle Thumb-2.
387 (thumb_find_work_register, arm_load_pic_register,
388 legitimize_tls_address, arm_address_cost, load_multiple_sequence,
389 emit_ldm_seq, emit_stm_seq, arm_select_cc_mode, get_jump_table_size,
390 print_multi_reg, output_mov_long_double_fpa_from_arm,
391 output_mov_long_double_arm_from_fpa, output_mov_double_fpa_from_arm,
392 output_mov_double_fpa_from_arm, output_move_double,
393 arm_compute_save_reg_mask, arm_compute_save_reg0_reg12_mask,
394 output_return_instruction, arm_output_function_prologue,
395 arm_output_epilogue, arm_get_frame_offsets, arm_regno_class,
396 arm_output_mi_thunk, thumb_set_return_address): Ditto.
397 (arm_expand_prologue): Handle Thumb-2. Use arm_save_coproc_regs.
398 (arm_coproc_mem_operand): Allow POST_INC/PRE_DEC.
399 (arithmetic_instr, shift_op): Use arm_shift_nmem.
400 (arm_print_operand): Use arm_print_condition. Handle '(', ')', '.',
402 (arm_final_prescan_insn): Use extract_constrain_insn_cached.
403 (thumb_expand_prologue): Use thumb_set_frame_pointer.
404 (arm_file_start): Output directive for unified syntax.
405 (arm_unwind_emit_set): Handle stack alignment instruction.
406 * config/arm/lib1funcs.asm: Remove default for __ARM_ARCH__.
407 Add v6t2, v7, v7a, v7r and v7m.
408 (RETLDM): Add Thumb-2 code.
409 (do_it, shift1, do_push, do_pop, COND, THUMB_SYNTAX): New macros.
410 * config/arm/arm.h (TARGET_CPU_CPP_BUILTINS): Define __thumb2__.
411 (TARGET_THUMB1, TARGET_32BIT, TARGET_THUMB2, TARGET_DSP_MULTIPLY,
412 TARGET_INT_SIMD, TARGET_UNIFIED_ASM, ARM_FT_STACKALIGN, IS_STACKALIGN,
413 THUMB2_TRAMPOLINE_TEMPLATE, TRAMPOLINE_ADJUST_ADDRESS,
414 ASM_OUTPUT_OPCODE, THUMB2_GO_IF_LEGITIMATE_ADDRESS,
415 THUMB2_LEGITIMIZE_ADDRESS, CASE_VECTOR_PC_RELATIVE,
416 CASE_VECTOR_SHORTEN_MODE, ADDR_VEC_ALIGN, ASM_OUTPUT_CASE_END,
417 ADJUST_INSN_LENGTH): Define.
418 (TARGET_REALLY_IWMMXT, TARGET_IWMMXT_ABI, CONDITIONAL_REGISTER_USAGE,
419 STATIC_CHAIN_REGNUM, HARD_REGNO_NREGS, INDEX_REG_CLASS,
420 BASE_REG_CLASS, MODE_BASE_REG_CLASS, SMALL_REGISTER_CLASSES,
421 PREFERRED_RELOAD_CLASS, SECONDARY_OUTPUT_RELOAD_CLASS,
422 SECONDARY_INPUT_RELOAD_CLASS, LIBCALL_VALUE, FUNCTION_VALUE_REGNO_P,
423 TRAMPOLINE_SIZE, INITIALIZE_TRAMPOLINE, HAVE_PRE_INCREMENT,
424 HAVE_POST_DECREMENT, HAVE_PRE_DECREMENT, HAVE_PRE_MODIFY_DISP,
425 HAVE_POST_MODIFY_DISP, HAVE_PRE_MODIFY_REG, HAVE_POST_MODIFY_REG,
426 REGNO_MODE_OK_FOR_BASE_P, LEGITIMATE_CONSTANT_P,
427 REG_MODE_OK_FOR_BASE_P, REG_OK_FOR_INDEX_P, GO_IF_LEGITIMATE_ADDRESS,
428 LEGITIMIZE_ADDRESS, THUMB2_LEGITIMIZE_ADDRESS,
429 GO_IF_MODE_DEPENDENT_ADDRESS, MEMORY_MOVE_COST, BRANCH_COST,
430 ASM_APP_OFF, ASM_OUTPUT_CASE_LABEL, ARM_DECLARE_FUNCTION_NAME,
431 FINAL_PRESCAN_INSN, PRINT_OPERAND_PUNCT_VALID_P,
432 PRINT_OPERAND_ADDRESS): Adjust for Thumb-2.
433 (arm_arch_notm, arm_arch_thumb2, arm_arch_hwdiv): New declarations.
434 * config/arm/arm-cores.def: Add arm1156t2-s, cortex-a8, cortex-r4 and
436 * config/arm/arm-tune.md: Regenerate.
437 * config/arm/arm-protos.h: Update prototypes.
438 * config/arm/vfp.md: Enable patterns for Thumb-2.
439 (arm_movsi_vfp): Add movw alternative. Use output_move_vfp.
440 (arm_movdi_vfp, movsf_vfp, movdf_vfp): Use output_move_vfp.
441 (thumb2_movsi_vfp, thumb2_movdi_vfp, thumb2_movsf_vfp,
442 thumb2_movdf_vfp, thumb2_movsfcc_vfp, thumb2_movdfcc_vfp): New.
443 * config/arm/libunwind.S: Add Thumb-2 code.
444 * config/arm/constraints.md: Update include Thumb-2.
445 * config/arm/ieee754-sf.S: Add Thumb-2/Unified asm support.
446 * config/arm/ieee754-df.S: Ditto.
447 * config/arm/bpabi.S: Ditto.
448 * config/arm/t-arm (MD_INCLUDES): Add thumb2.md.
449 * config/arm/predicates.md (low_register_operand,
450 low_reg_or_int_operand, thumb_16bit_operator): New.
451 (thumb_cmp_operand, thumb_cmpneg_operand): Rename...
452 (thumb1_cmp_operand, thumb1_cmpneg_operand): ... to this.
453 * config/arm/t-arm-elf: Add armv7 multilib.
454 * config/arm/arm.md: Update patterns for Thumb-2 and Unified asm.
456 (UNSPEC_STACK_ALIGN, ce_count): New.
457 (arm_incscc, arm_decscc, arm_umaxsi3, arm_uminsi3,
458 arm_zero_extendsidi2, arm_zero_extendqidi2): New
460 * config/arm/fpa.md: Update patterns for Thumb-2 and Unified asm.
461 (thumb2_movsf_fpa, thumb2_movdf_fpa, thumb2_movxf_fpa,
462 thumb2_movsfcc_fpa, thumb2_movdfcc_fpa): New insns.
463 * config/arm/cirrus.md: Update patterns for Thumb-2 and Unified asm.
464 (cirrus_thumb2_movdi, cirrus_thumb2_movsi_insn,
465 thumb2_cirrus_movsf_hard_insn, thumb2_cirrus_movdf_hard_insn): New
467 * doc/extend.texi: Document ARMv7-M interrupt functions.
468 * doc/invoke.texi: Document Thumb-2 new cores+architectures.
470 2007-01-03 Jakub Jelinek <jakub@redhat.com>
472 * unwind-dw2.c (SIGNAL_FRAME_BIT, EXTENDED_CONTEXT_BIT): Define.
473 (struct _Unwind_Context): Rename args_size to flags, remove
474 signal_frame field, add a new args_size field and version field.
475 (_Unwind_IsSignalFrame, _Unwind_SetSignalFrame,
476 _Unwind_IsExtendedContext): New inline functions.
477 (_Unwind_GetGR, _Unwind_SetGR, _Unwind_GetGRPtr, _Unwind_SetGRPtr):
478 Assume by_value array is only present if _Unwind_IsExtendedContext.
479 (_Unwind_GetIPInfo, execute_cfa_program, uw_frame_state_for): Use
480 _Unwind_IsSignalFrame.
481 (__frame_state_for): Initialize context.flags to EXTENDED_CONTEXT_BIT.
482 (uw_update_context_1): Use _Unwind_SetSignalFrame.
483 (uw_init_context_1): Initialize context->flags to
484 EXTENDED_CONTEXT_BIT.
485 * config/rs6000/linux-unwind.h (frob_update_context): Use
486 _Unwind_SetSignalFrame.
488 2007-01-03 Andrew Pinski <andrew_pinski@playstation.sony.com>
491 * gimplify.c (gimplify_modify_expr_complex_part): Move below
492 tree_to_gimple_tuple. Call tree_to_gimple_tuple when we need
495 2007-01-03 Kazu Hirata <kazu@codesourcery.com>
497 * config/i386/i386.h (NON_STACK_REG_P, REGNO_OK_FOR_SIREG_P,
498 REGNO_OK_FOR_DIREG_P, REWRITE_ADDRESS, ASM_OPERAND_LETTER,
500 * config/i386/i386.md (*sse_prologue_save_insn): Use return
503 * alias.c (init_alias_analysis): Use VEC_safe_grow_cleared.
504 * cfgbuild.c (find_basic_blocks): Likewise.
505 * cfgrtl.c (rtl_create_basic_block): Likewise.
506 * function.c (temp_slots_at_level): Likewise.
507 * reg-stack.c (stack_regs_mentioned): Likewise.
508 * regclass.c (allocate_reg_info): Likewise.
509 * tree-cfg.c (init_empty_tree_cfg, build_tree_cfg, create_bb,
510 set_bb_for_stmt, move_block_to_fn): Likewise.
511 * tree-complex.c (tree_lower_complex): Likewise.
512 * vec.h (VEC_safe_grow_cleared): New.
514 * cgraphunit.c, tree-ssa-alias.c: Fix comment typos.
516 2007-01-03 Zdenek Dvorak <dvorakz@suse.cz>
518 * loop-unswitch.c (unswitch_loop): Pass probabilities to loopify.
519 * tree-ssa-loop-unswitch.c (tree_unswitch_loop): Pass probabilities
521 * cfgloopmanip.c (scale_loop_frequencies): Export.
522 (loopify): Scale the frequencies by prescribed coefficients.
523 (set_zero_probability): New function.
524 (duplicate_loop_to_header_edge): Improve updating of frequencies.
525 (lv_adjust_loop_entry_edge, loop_version): Set probabilities
526 and frequencies according to arguments.
527 * tree-ssa-loop-manip.c (tree_unroll_loop): Set probabilities
529 * cfg.c (scale_bbs_frequencies_int): Allow scaling the frequencies up.
530 * modulo-sched.c (sms_schedule): Set probabilities for entering
531 versioned loop correctly.
532 * tree-vect-transform.c (vect_transform_loop): Ditto.
533 * cfgloop.h (loopify, loop_version): Declaration changed.
534 (scale_loop_frequencies): Declared.
536 2007-01-02 Jan Hubicka <jh@suse.cz>
538 * cgraph.c: Include tree-flow.h
539 (cgraph_add_new-function): Handle IPA_SSA mode; execute
541 * cgraph.h (enum cgraph_state): Add CGRAPH_STATE_IPA_SSA.
542 * tree-pass.h (pass_all_early_optimizations): Declare.
543 * cgraphunit.c (cgraph_process_new_functions): Add IPA_SSA; execute
545 (cgraph_analyze_function): Do early_local_passes.
546 * tree-mudflap.c (mf_decl_cache_locals, mf_build_check_statement_for):
547 Do not add referenced vars.
548 * tree-optimize.c (gate_all_optimizations): Do not execute when not in
550 (gate_all_early_local_passes): New gate.
551 (pass_early_local_passes): Use new gate.
552 (execute_early_local_optimizations): New functions.
553 (gate_all_early_optimizations): New gate.
554 (pass_all_early_optimizations): New pass.
555 (execute_free_datastructures): Free SSA only when initialized.
556 (gate_init_datastructures): Init only when optimizing.
557 (tree_lowering_passes): Do early local passes when called late.
558 * tree-profile.c (do_tree_profiling): Don't profile functions added
560 (do_early_tree_profiling, pass_early_tree_profile): Kill.
561 * tree-cfg.c (update_modified_stmts): Do not update when operands are
563 * passes.c (init_optimizations_passes): Reorder so we go into SSA
564 during early_local_passes.
565 * Makefile.in (cgraph.o): Add dependency on tree-flow.h.
568 2007-01-02 Carlos O'Donell <carlos@codesourcery.com>
570 * Makefile.in: Update copyright year.
572 2007-01-02 Carlos O'Donell <carlos@codesourcery.com>
574 * Makefile.in: Export GCC_EXEC_PREFIX before calling $(RUNTEST)
575 in $(lang_checks) and check-consistency targets.
577 2007-01-02 Jan Hubicka <jh@suse.cz>
579 * tree-mudflap.c (mf_decl_cache_locals, mf_build_check_statement_for):
580 Do not add referenced vars.
581 * tree-cfg.c (update_modified_stmts): Do not update when SSA operands
583 * passes.c (init_optimization_passes): Put mudflap_2 after
586 2007-01-02 Jan Hubicka <jh@suse.cz>
588 * tree-optimize (execute_fixup_cfg): Set after_inlining flag.
589 Set NOTHROW flag on call statements proved to be nothrow.
590 Update statement of local calls so new pure/const functions are
591 updated. Update_ssa when in ssa form. Mark PHI nodes of nonlocal
593 (tree_rest_of_compilation): Register hooks and initialize bitmap
594 early. Do not set after_inlining flag.
596 2007-01-02 Steve Ellcey <sje@cup.hp.com>
598 * sbitmap.c (HOST_BITS_PER_LONG_LONG): Change to
599 HOST_BITS_PER_LONGLONG
601 2007-01-02 Manuel Lopez-Ibanez <manu@gcc.gnu.org>
604 * c-typeck.c (store_init_value): Don't emit pedantic overflow
605 warning for non-static initializers.
607 2007-01-02 Steven Bosscher <steven@gcc.gnu.org>
609 * config/alpha/alpha.md, arm/arm.c, darwin.c, frv/frv.md,
610 m32r/m32r.c, m32r/m32r.c, mn10300/mn10300.md, pa/pa.c,
611 rs6000/rs6000.c, s390/s390.md, sh/sh.md, sparc/sparc.c:
612 Always use set_unique_reg_note to add REG_EQUAL notes.
614 2007-01-02 Kazu Hirata <kazu@codesourcery.com>
617 2007-01-02 Kazu Hirata <kazu@codesourcery.com>
619 * alias.c (init_alias_analysis): Use VEC_safe_grow_cleared.
620 * cfgbuild.c (find_basic_blocks): Likewise.
621 * cfgrtl.c (rtl_create_basic_block): Likewise.
622 * function.c (temp_slots_at_level): Likewise.
623 * reg-stack.c (stack_regs_mentioned): Likewise.
624 * regclass.c (allocate_reg_info): Likewise.
625 * tree-cfg.c (init_empty_tree_cfg, build_tree_cfg, create_bb,
626 set_bb_for_stmt, move_block_to_fn): Likewise.
627 * tree-complex.c (tree_lower_complex): Likewise.
628 * vec.h (VEC_safe_grow_cleared): New.
630 2007-01-02 Ian Lance Taylor <iant@google.com>
632 * c-common.c (c_common_truthvalue_conversion): When warning about
633 using an assignment as a truth value, set TREE_NO_WARNING.
635 2007-01-02 Manuel Lopez-Ibanez <manu@gcc.gnu.org>
638 * c.opt (Wold-style-declaration): New.
639 * doc/invoke.texi (C-only Warning Options): New.
640 (Wold-style-declaration): Document it.
641 (Wextra): Enabled by -Wextra.
642 * c-opts.c (c_common_post_options): Enabled by -Wextra.
643 * c-decl.c (declspecs_add_scspec): Replace -Wextra with
644 -Wold-style-declaration.
646 2007-01-02 Kazu Hirata <kazu@codesourcery.com>
648 * alias.c (init_alias_analysis): Use VEC_safe_grow_cleared.
649 * cfgbuild.c (find_basic_blocks): Likewise.
650 * cfgrtl.c (rtl_create_basic_block): Likewise.
651 * function.c (temp_slots_at_level): Likewise.
652 * reg-stack.c (stack_regs_mentioned): Likewise.
653 * regclass.c (allocate_reg_info): Likewise.
654 * tree-cfg.c (init_empty_tree_cfg, build_tree_cfg, create_bb,
655 set_bb_for_stmt, move_block_to_fn): Likewise.
656 * tree-complex.c (tree_lower_complex): Likewise.
657 * vec.h (VEC_safe_grow_cleared): New.
659 2007-01-02 Douglas Gregor <doug.gregor@gmail.com>
661 * c-common.c(c_common_nodes_and_builtins): Since variants of
662 void_type_node get built before it is given a name, we need to
663 give those variants the name, too.
664 (complete_array_type): We need to work with the canonical main
665 type of the array, from which we will build the qualified version.
666 * params.def (PARAM_VERIFY_CANONICAL_TYPES): New.
667 * print-tree.c (print_node): Display canonical type information
669 * stor-layout.c (layout_type): When we don't know the
670 alignment of a type for which we're building an array, we end up
671 guessing wrong, so make the type require structural equality.
672 * tree.c (make_node_stat): When we build a new type, it is its
674 (build_type_attribute_qual_variant): When building an attribute
675 variant, its canonical type is the non-attribute variant. However,
676 if the attributes are target-dependent and they differ, we need to
677 use structural equality checks for this type.
678 (build_qualified_type): A qualified type is not equivalent to its
679 unqualified variant; set the canonical type appropriately.
680 (build_distinct_type_copy): When building a distinct type from
681 another type, the new type is its own canonical type.
682 (build_variant_type_copy): When building a new type variant, we
683 assume that it is equivalent to the original type.
684 (build_pointer_type_for_mode): When building a pointer type, also
685 build a canonical type pointer.
686 (build_reference_type_for_mode): When building a reference type,
687 also build a canonical type reference.
688 (build_index_type): When we can't hash an index type (e.g.,
689 because its maximum value is negative), the index type requires
690 structural equality tests.
691 (build_array_type): Build the canonical form of an array type.
692 (build_function_type): Function types require structural equality,
693 because they contain default arguments, attributes, etc.
694 (build_method_type_directly): Ditto for method types.
695 (build_offset_type): Build the canonical offset type.
696 (build_complex_type): Build the canonical vector type.
697 (make_vector_type): Build the canonical vector type.
698 * tree.h (TYPE_CANONICAL): New.
699 (TYPE_STRUCTURAL_EQUALITY_P): New.
700 (SET_TYPE_STRUCTURAL_EQUALITY): New.
701 (struct tree_type): Added "canonical" field.
702 * params.h (VERIFY_CANONICAL_TYPES): New.
703 * doc/c-tree.texi (TYPE_CANONICAL): Document.
704 (TYPE_STRUCTURAL_EQUALITY_P): Document.
705 (SET_TYPE_STRUCTURAL_EQUALITY): Document.
706 * doc/invoke.texi (verify-canonical-types): Document --param
707 parameter for verifying canonical types.
709 2007-01-02 Joseph Myers <joseph@codesourcery.com>
711 * config.gcc (powerpc-*-eabispe*, powerpc-*-eabisimaltivec*,
712 powerpc-*-eabisim*, powerpc-*-eabialtivec*, powerpc-*-eabi*,
713 powerpc-*-rtems*, powerpc-wrs-vxworks, powerpc-wrs-vxworksae,
714 powerpcle-*-eabisim*, powerpcle-*-eabi*): Add rs6000/e500.h to
716 * config/rs6000/e500.h: New.
717 * config/rs6000/eabi.h (TARGET_SPE_ABI, TARGET_SPE, TARGET_E500,
718 TARGET_ISEL, TARGET_FPRS, TARGET_E500_SINGLE, TARGET_E500_DOUBLE):
720 * config/rs6000/linuxspe.h (TARGET_SPE_ABI, TARGET_SPE,
721 TARGET_E500, TARGET_ISEL, TARGET_FPRS, TARGET_E500_SINGLE,
722 TARGET_E500_DOUBLE): Remove.
723 * config/rs6000/vxworks.h (TARGET_SPE_ABI, TARGET_SPE,
724 TARGET_E500, TARGET_ISEL, TARGET_FPRS): Remove.
725 * config/rs6000/rs6000.h (CHECK_E500_OPTIONS): Define.
726 * config/rs6000/rs6000.c (rs6000_override_options): Use
729 2007-01-02 Joseph Myers <joseph@codesourcery.com>
731 * config/rs6000/rs6000.c (print_operand): Check (TARGET_SPE ||
732 TARGET_E500_DOUBLE), not TARGET_E500, for %y.
733 (rs6000_generate_compare, rs6000_emit_sCOND, output_cbranch,
734 rs6000_emit_cmove): Don't check TARGET_E500.
735 * config/rs6000/rs6000.md (bunordered, bordered, sunordered,
736 sordered): Don't check TARGET_E500.
738 2007-01-01 Eric Christopher <echristo@apple.com>
740 * config/mips/mips.c (mips_regno_mode_ok_for_base_p): Use
743 2007-01-01 Roger Sayle <roger@eyesopen.com>
745 * fold-const.c (fold_binary) <EQ_EXPR>: Fold "(X^C1) eq/ne C2" into
746 "X eq/ne (C1^C2)". Fold "(X^Z) eq/ne (Y^Z)" as "X eq/ne Y" when Z
747 has no side-effects. Fold "(X^C1) eq/ne (Y^C2)" as "(X^(C1^C2))
750 2007-01-01 Mike Stump <mrs@apple.com>
752 * configure.ac: Remove support for building with Apple's gcc-3.1.
754 2007-01-02 Joseph Myers <joseph@codesourcery.com>
757 * caller-save.c (add_stored_regs): Only handle SUBREGs if inner
758 REG is a hard register. Do not modify REG before calling
760 * rtlanal.c (subreg_get_info): Don't assert size of XMODE is a
761 multiple of the size of YMODE for certain lowpart cases.
763 2007-01-01 Andrew Pinski <pinskia@gmail.com>
766 * gimplify (voidify_wrapper_expr): Update for
769 2007-01-01 Andreas Schwab <schwab@suse.de>
772 * config/ia64/ia64.c (ia64_compute_frame_size): Account space for
773 save of BR0 in extra_spill_size instead of spill_size.
774 (ia64_expand_prologue): Save BR0 outside of the gr/br/fr spill
776 (ia64_expand_epilogue): Restore BR0 from its new location.
778 2007-01-01 Andrew Pinski <pinskia@gmail.com>
780 * gimplify.c (gimplify_init_constructor <case VECTOR_TYPE>):
781 Use a temporary variable if the left hand side is not a gimple
784 2007-01-01 Andrew Pinski <pinskia@gmail.com>
786 * gimplify.c (gimplify_return_expr): Make the temporary variable
787 for the return expression, a gimple register variable.
789 2007-01-01 Jan Hubicka <jh@suse.cz>
791 * emit-rtl.c (emit_copy_of_insn_after): Do not call copy_insn_1 for
794 2007-01-01 Mike Stump <mrs@apple.com>
796 * configure.ac (HAVE_GAS_LITERAL16): Add autoconf check for
798 * config/darwin.c (machopic_select_rtx_section): Use
800 (darwin_mergeable_constant_section): Likewise.
801 * configure: Regenerate.
802 * config.in: Regenerate.
804 2007-01-01 Jan Hubicka <jh@suse.cz>
805 Andrew Pinski <pinskia@gmail.com>
807 * cgraphunit.c (cgraph_optimize): Call cgraph_add_new_functions
808 before starting IPA passes.