OSDN Git Service

f3c186ee1d7673ca55941dd9329346ecae8caf7f
[pf3gnuchains/gcc-fork.git] / gcc / ChangeLog
1 2009-01-16  Richard Guenther  <rguenther@suse.de>
2
3         PR tree-optimization/38835
4         PR middle-end/36227
5         * fold-const.c (fold_binary): Remove PTR + INT -> (INT)(PTR p+ INT)
6         and INT + PTR -> (INT)(PTR p+ INT) folding.
7         * tree-ssa-address.c (create_mem_ref): Properly use POINTER_PLUS_EXPR.
8
9 2009-01-16  Adam Nemet  <anemet@caviumnetworks.com>
10
11         PR target/38554
12         * expmed.c (expand_shift): With SHIFT_COUNT_TRUNCATED, don't lift
13         the subreg from a lowpart subreg if it is also casting the value.
14
15 2009-01-16  Sebastian Pop  <sebastian.pop@amd.com>
16             Tobias Grosser  <tobi.grosser@amd.com>
17
18         * graphite.c (compare_prefix_loops): New.
19         (build_scop_canonical_schedules): Rewritten.
20         (graphite_transform_loops): Move build_scop_canonical_schedules
21         after build_scop_iteration_domain.
22
23 2009-01-16  Sebastian Pop  <sebastian.pop@amd.com>
24             Tobias Grosser  <tobi.grosser@amd.com>
25
26         * graphite.c (add_conditions_to_domain): Add the loops to 
27         the dimension of the iteration domain.  Do copy the domain
28         only when it exists.
29         (build_scop_conditions_1): Do not call add_conditions_to_domain.
30         (add_conditions_to_constraints): New.
31         (can_generate_code_stmt, can_generate_code): Removed.
32         (gloog): Do not call can_generate_code.
33         (graphite_transform_loops): Call add_conditions_to_constraints
34         after building the iteration domain.
35
36 2009-01-16  Jakub Jelinek  <jakub@redhat.com>
37
38         PR tree-optimization/38789
39         * tree-ssa-threadedge.c
40         (record_temporary_equivalences_from_stmts_at_dest): Ignore calls to
41         __builtin_constant_p.
42
43 2009-01-16  Kenneth Zadeck <zadeck@naturalbridge.com>
44
45         * dce.c (delete_unmarked_insns): Reversed the order that insns are
46         examined before deleting them.
47         
48 2009-01-16  Richard Earnshaw  <rearnsha@arm.com>
49
50         * function.c (aggregate_value_p): Correctly extract the function
51         type from CALL_EXPR_FN lookup.
52
53 2009-01-16  Hariharan Sandanagobalane <hariharan@picochip.com>
54
55         * config/picochip/picochip.c (picochip_override_options): Revert
56         CFI asm flag disable commited previously.
57
58 2009-01-15  Sebastian Pop  <sebastian.pop@amd.com>
59             Tobias Grosser  <tobi.grosser@amd.com>
60             Jan Sjodin  <jan.sjodin@amd.com>
61
62         * graphite.c (scan_tree_for_params): On substractions negate
63         all the coefficients of the term.
64         (clast_to_gcc_expression_red): New.  Handle reduction expressions
65         of more than two operands.
66         (clast_to_gcc_expression): Call clast_to_gcc_expression_red.
67         (get_vdef_before_scop): Handle also the case of default definitions.
68
69 2009-01-15  Richard Sandiford  <rdsandiford@googlemail.com>
70
71         * caller-save.c (add_used_regs_1, add_used_regs): New functions.
72         (insert_one_insn): Use them instead of REG_DEAD and REG_INC notes.
73         Also use them when walking CALL_INSN_FUNCTION_USAGE.
74
75 2009-01-15  H.J. Lu  <hongjiu.lu@intel.com>
76             Joey Ye  <joey.ye@intel.com>
77
78         PR middle-end/37843
79         * cfgexpand.c (expand_stack_alignment): Don't update stack
80         boundary nor check incoming stack boundary here.
81         (gimple_expand_cfg): Update stack boundary and check incoming
82         stack boundary here.
83
84 2009-01-15  Kenneth Zadeck <zadeck@naturalbridge.com>
85
86         * dce.c (find_call_stack_args, delete_unmarked_insns): Fixed
87         comments.
88         
89 2009-01-14  Jakub Jelinek  <jakub@redhat.com>
90
91         PR rtl-optimization/38245
92         * calls.c (expand_call): Add stack arguments to
93         CALL_INSN_FUNCTION_USAGE even for pure calls (when
94         ACCUMULATE_OUTGOING_ARGS) and even for args partially passed
95         in regs and partially in memory or BLKmode arguments.
96         (emit_library_call_value_1): Add stack arguments to
97         CALL_INSN_FUNCTION_USAGE even for pure calls (when
98         ACCUMULATE_OUTGOING_ARGS).
99         * dce.c: Include tm_p.h.
100         (find_call_stack_args): New function.
101         (deletable_insn_p): Call it for CALL_P insns.  Add ARG_STORES
102         argument.
103         (mark_insn): Call find_call_stack_args for CALL_Ps.
104         (prescan_insns_for_dce): Walk insns backwards in bb rather than
105         forwards.  Allocate and free arg_stores bitmap if needed, pass it
106         down to deletable_insn_p, don't mark stores set in arg_stores
107         bitmap, clear the bitmap at the beginning of each bb.
108         * Makefile.in (dce.o): Depend on $(TM_P_H).
109
110 2009-01-14  Michael Meissner  <gnu@the-meissners.org>
111
112         PR target/22599
113         * i386.c (print_operand): Add tests for 'D', 'C', 'F', 'f' to make
114         sure the insn is a conditional test (bug 22599).  Reformat a few long
115         lines.
116
117 2009-01-14  Sebastian Pop  <sebastian.pop@amd.com>
118
119         PR middle-end/38431
120         * graphite.c (get_vdef_before_scop, scop_adjust_vphi): New.
121         (scop_adjust_phis_for_liveouts): Call scop_adjust_vphi.
122         (gloog): Do not call cleanup_tree_cfg.
123         (graphite_transform_loops): Call cleanup_tree_cfg after all 
124         scops have been code generated.
125
126 2009-01-14  Vladimir Makarov  <vmakarov@redhat.com>
127
128         * testsuite/g++.dg/torture/pr38811.C: New file.
129
130 2009-01-14  Basile Starynkevitch  <basile@starynkevitch.net>
131         * doc/gty.texi (Invoking the garbage collector): Added new node
132         and section documenting ggc_collect.
133
134 2009-01-14  Richard Guenther  <rguenther@suse.de>
135
136         PR tree-optimization/38826
137         PR middle-end/38477
138         * tree-ssa-structalias.c (emit_alias_warning): Emit the pointer
139         initialization notes only if we actually emitted a warning.
140         (intra_create_variable_infos): Add constraints for a result decl
141         that is passed by hidden reference.
142         (build_pred_graph): Mark all related variables non-direct on
143         address-taking.
144
145 2009-01-14  Nick Clifton  <nickc@redhat.com>
146
147         * ira-conflicts.c: Include addresses.h for the definition of
148         base_reg_class.
149         (ira_build_conflicts): Use base_reg_class instead of
150         BASE_REG_CLASS.
151         * Makefile.in: Add a dependency of ira-conflicts.o on
152         addresses.h.
153
154 2009-01-13  Vladimir Makarov  <vmakarov@redhat.com>
155
156         PR target/38811
157         * Makefile.in (ira-lives.o): Add except.h.
158
159         * ira-lives.c: Include except.h.
160         (process_bb_node_lives): Process can_throw_internal.
161
162 2009-01-13  Jakub Jelinek  <jakub@redhat.com>
163
164         PR rtl-optimization/38774
165         * combine.c (simplify_set): When undoing cc_use change, don't do
166         PUT_CODE on the newly created comparison, but instead put back the
167         old comparison.
168
169 2009-01-13  Joseph Myers  <joseph@codesourcery.com>
170
171         * doc/invoke.texi (ARM Options): Update lists of -mcpu and -march
172         values.  Remove duplicate arm8 entry.
173
174 2009-01-13  Sebastian Pop  <sebastian.pop@amd.com>
175
176         PR tree-optimization/38786
177         * graphite.c (expand_scalar_variables_ssa_name): New, outlined from
178         the SSA_NAME case of expand_scalar_variables_expr.
179         Set the type of an expression to the type of its assign statement.
180         (expand_scalar_variables_expr): Also gather the scalar computation
181         used to index the memory access.  Do not pass loop_p.
182         Fix comment.  Stop recursion on tcc_constant or tcc_declaration.
183         (expand_scalar_variables_stmt): Pass to expand_scalar_variables_expr
184         the gimple_stmt_iterator where it inserts new code.  Do not pass loop_p.
185         (copy_bb_and_scalar_dependences): Do not pass loop_p.
186         (translate_clast): Update call to copy_bb_and_scalar_dependences.
187
188 2009-01-13  Sebastian Pop  <sebastian.pop@amd.com>
189
190         * graphite.h (debug_value): Removed.
191         * graphite.c (debug_value): Removed.
192
193 2009-01-13  Richard Earnshaw  <rearnsha@arm.com>
194
195         * arm.c (output_move_double): Don't synthesize thumb-2 ldrd/strd with
196         two 32-bit instructions.
197
198 2009-01-13  Richard Earnshaw  <rearnsha@arm.com>
199
200         * arm.c (struct processors): Pass for speed down into cost helper
201         functions.
202         (const_ok_for_op): Handle COMPARE and inequality nodes.
203         (arm_rtx_costs_1): Rewrite.
204         (arm_size_rtx_costs): Update prototype.
205         (arm_rtx_costs): Pass speed down to helper functions.
206         (arm_slowmul_rtx_costs): Rework cost calculations.
207         (arm_fastmul_rtx_costs, arm_xscale_rtx_costs): Likewise.
208         (arm_9e_rtx_costs): Likewise.
209
210 2009-01-13  Uros Bizjak  <ubizjak@gmail.com>
211
212         * config/alpha/alpha.c (alpha_legitimate_address_p): Explicit
213         relocations of local symbols  wider than UNITS_PER_WORD are not valid.
214         (alpha_legitimize_address): Do not split local symbols wider than
215         UNITS_PER_WORD into HIGH/LO_SUM parts.
216
217 2009-01-13  Danny Smith  <dannysmith@users.sourceforge.net>
218
219         PR bootstrap/38580
220         * gcc.c (process_command): Replace call to execvp with calls
221         to pex_one and exit.
222
223 2009-01-03  Anatoly Sokolov  <aesok@post.ru>
224
225         PR target/29141
226         * config/avr/t-avr (LIB1ASMFUNCS): Add _tablejump_elpm.
227         * config/avr/libgcc.S (__do_global_ctors, __do_global_dtors): Add
228         variant for devices with 3-byte PC.
229         (__tablejump_elpm__) : New.
230
231 2009-01-12  Jakub Jelinek  <jakub@redhat.com>
232
233         PR c/32041
234         * c-parser.c (c_parser_postfix_expression): Allow `->' in
235         offsetof member-designator, handle it as `[0].'.
236
237 2009-01-12  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
238
239         * pa.c (pa_asm_output_mi_thunk): Use pc-relative branch to thunk
240         function when not using named sections on targets with named sections
241         if branch distance is less than 262132.
242
243 2009-01-12  Richard Earnshaw  <rearnsha@arm.com>
244
245         * combine.c (combine_instructions):  Recompute
246         optimize_this_for_speed_p  for each BB in the main combine loop.
247
248 2009-01-12  Tomas Bily  <tbily@suse.cz>
249
250         PR middlend/38385
251         * tree-loop-distribution.c (prop_phis): New function.
252         (generate_builtin): Call prop_phis.
253         * testsuite/gcc.dg/tree-ssa/pr38385.c: New file.
254
255 2009-01-12  Jakub Jelinek  <jakub@redhat.com>
256
257         PR tree-optimization/38807
258         * tree-ssa-reassoc.c (remove_visited_stmt_chain): Don't look at
259         gimple_visited_p unless stmt is GIMPLE_ASSIGN.
260
261 2009-01-11  Adam Nemet  <anemet@caviumnetworks.com>
262
263         * expmed.c (store_bit_field_1): Properly truncate the paradoxical
264         subreg of op0 to the original op0.
265
266 2009-01-11  Laurent GUERBY <laurent@guerby.net>
267
268         * doc/sourcebuild.texi (Source Tree): Move up intl and fixinc.
269         
270 2009-01-11  Markus Schoepflin  <markus.schoepflin@comsoft.de>
271
272         PR debug/7055
273         * gcc/mips-tfile.c (parse_def): Fix parsing of def strings
274         starting with digits.
275
276 2009-01-10  Jakub Jelinek  <jakub@redhat.com>
277
278         PR target/38695
279         * config/arm/arm.c (arm_is_long_call_p): Don't call
280         arm_function_in_section_p if decl isn't a FUNCTION_DECL.
281
282 2009-01-09  Steven Bosscher  <steven@gcc.gnu.org>
283
284         * regrename.c (regrename_optimize): Fix dumping.
285         (find_oldest_value_reg): Preserve REG_POINTER.
286         (copy_hardreg_forward_1): Likewise.
287
288 2009-01-09  Diego Novillo  <dnovillo@google.com>
289
290         * gimple.h (struct gimple_statement_base)<uid>: Document
291         the restrictions on its use.
292         (gimple_uid): Tidy.
293         (gimple_set_uid): Tidy.
294
295 2009-01-09  Jakub Jelinek  <jakub@redhat.com>
296
297         * config/i386/i386.c (ix86_expand_movmem, ix86_expand_setmem): Add
298         zero guard even if align_bytes != 0 and count is smaller than
299         size_needed.
300
301 2008-01-09  Vladimir Makarov  <vmakarov@redhat.com>
302
303         PR rtl-optimization/38495
304         * ira-emit.c (print_move_list, ira_debug_move_list): New functions.
305         (add_range_and_copies_from_move_list): Print all added ranges.
306         Add ranges to memory optimized destination.
307
308 2009-01-09  Jakub Jelinek  <jakub@redhat.com>
309
310         PR target/38686
311         PR target/38708
312         * config/i386/i386.c (override_options): Reject
313         -mstringop-strategy=rep_8byte with -m32.
314         (ix86_expand_movmem): For size_needed == 1 set epilogue_size_needed
315         to 1.  Do count comparison against epilogue_size_needed at compile
316         time even when count_exp was constant forced into register.  For
317         size_needed don't jump to epilogue, instead just avoid aligning
318         and invoke the body algorithm.  If need_zero_guard, add zero guard
319         even if count is non-zero, but smaller than size_needed + number of
320         bytes that could be stored for alignment.
321         (ix86_expand_setmem): For size_needed == 1 set epilogue_size_needed
322         to 1.  If need_zero_guard, add zero guard even if count is non-zero,
323         but smaller than size_needed + number of bytes that could be stored
324         for alignment.  Compare size_needed with epilogue_size_needed instead
325         of desired_align - align, don't adjust size_needed, pass
326         epilogue_size_needed to the epilogue expanders.
327
328         PR c/35742
329         * c-pretty-print.c (pp_c_expression): Handle GOTO_EXPR like BIND_EXPR.
330
331 2009-01-09  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
332
333         * pa.c (last_address): Change to unsigned.
334         (update_total_code_bytes): Change argument to unsigned.  Don't
335         check if insn addresses are set.
336         (pa_output_function_epilogue): Set last_address to UINT_MAX if insn
337         addresses are not set.
338         (pa_asm_output_mi_thunk): Handle wrap when updating last_address.
339
340 2009-01-09  Nick Clifton  <nickc@redhat.com>
341
342         * config/sh/symbian.c: Replace uses of DECL_INLINE with
343         DECL_DECLARED_INLINE_P.
344
345 2009-01-09  Jakub Jelinek  <jakub@redhat.com>
346
347         PR middle-end/38347
348         * dojump.c (do_jump_by_parts_zero_rtx): Use mode instead of
349         GET_MODE (op0) in operand_subword_force calls.
350
351         PR middle-end/38771
352         * fold-const.c (fold_unary): For COMPOUND_EXPR and COND_EXPR,
353         fold_convert arg0 operands to TREE_TYPE (op0) first.
354
355 2009-01-08  Vladimir Makarov  <vmakarov@redhat.com>
356
357         * params.def (ira-max-conflict-table-size): Decrease default value
358         to 1000.
359
360 2009-01-08  Jakub Jelinek  <jakub@redhat.com>
361
362         PR tree-optimization/37031
363         * lambda-code.c (lambda_collect_parameters): Call pointer_set_destroy
364         on parameter_set.
365         (build_access_matrix): Reserve correct size for AM_MATRIX vector,
366         allocate it using gc instead of heap, use VEC_quick_push instead of
367         VEC_safe_push.
368         * graphite.c (build_access_matrix): Allocate AM_MATRIX vector using gc
369         instead of heap, use VEC_quick_push instead of VEC_safe_push.
370         * tree-data-ref.h (struct access_matrix): Change matrix to gc
371         allocated vector from heap allocated.
372         * lambda.h: Add DEF_VEC_ALLOC_P for gc allocated lambda_vector.
373         * tree-loop-linear.c (linear_transform_loops): Allocate nest
374         vector only after perfect_loop_nest_depth call.
375
376 2009-01-08  Sebastian Pop  <sebastian.pop@amd.com>
377             Jan Sjodin  <jan.sjodin@amd.com>
378
379         PR tree-optimization/38559
380         * graphite.c (debug_value, copy_constraint,
381         swap_constraint_variables, scale_constraint_variable, ): New.
382         (get_lower_bound, get_upper_bound): Removed.
383         (graphite_trans_bb_strip_mine): Clean up this code that works
384         only for constant number of iterations.  Fully copy upper and
385         lower bound constraints, not only the constant part of them.
386         * graphite.h (debug_value): Declared.
387
388 2009-01-08  Ira Rosen  <irar@il.ibm.com>
389
390         PR tree-optimization/37194
391         * tree-vect-transform.c (vect_estimate_min_profitable_iters):
392         Don't add the cost of cost model guard in prologue to scalar 
393         outside cost in case of known number of iterations.
394
395 2009-01-07  Nathan Froyd  <froydnj@codesourcery.com>
396             Alan Modra  <amodra@bigpond.net.au>
397
398         * config/rs6000/rs6000.c (rs6000_legitimize_address): Check for
399         non-word-aligned REG+CONST addressing.
400
401 2009-01-07  Uros Bizjak  <ubizjak@gmail.com>
402
403         PR target/38706
404         * config/alpha/alpha.c (alpha_end_function): For TARGET_ABI_OSF, call
405         free_after_compilation when outputting a thunk.
406         (alpha_output_mi_thunk_osf): Assert that we are processing a thunk.
407         Do not call free_after_compilation here.
408
409 2009-01-07  Uros Bizjak  <ubizjak@gmail.com>
410
411         * config/i386/i386.c (ix86_target_string): Use ARRAY_SIZE.
412         (ix86_valid_target_attribute_inner_p): Ditto.
413
414 2009-01-07  Jan Sjodin  <jan.sjodin@amd.com>
415
416         PR tree-optimization/38492
417         PR tree-optimization/38498
418         * tree-check.c (operator_is_linear, scev_is_linear_expression): New.
419         * tree-chrec.h (scev_is_linear_expression): Declared.
420         * graphite.c (graphite_cannot_represent_loop_niter): New.
421         (scopdet_basic_block_info): Call graphite_cannot_represent_loop_niter.
422         (graphite_loop_normal_form): Use gcc_assert.
423         (scan_tree_for_params): Use CASE_CONVERT.
424         (phi_node_is_iv, bb_contains_non_iv_scalar_phi_nodes): New.
425         (build_scop_conditions_1): Call bb_contains_non_iv_scalar_phi_nodes.
426         Use gcc_assert.  Discard scops that contain unhandled cases.
427         (build_scop_conditions): Return a boolean status for unhandled cases.
428         (strip_mine_profitable_p): Print the loop number, not its depth.
429         (is_interchange_valid): Pass the depth of the loop nest, don't
430         recompute it wrongly.
431         (graphite_trans_bb_block): Same.
432         (graphite_trans_bb_block): Print tentative of loop blocking.
433         (graphite_trans_scop_block): Do not print that the loop has been
434         blocked.
435         (graphite_transform_loops): Do not handle scops that contain condition
436         scalar phi nodes.
437
438 2009-01-07  H.J. Lu  <hongjiu.lu@intel.com>
439
440         AVX Programming Reference (December, 2008)
441         * config/i386/avxintrin.h (_mm256_stream_si256): New.
442         (_mm256_stream_pd): Likewise.
443         (_mm256_stream_ps): Likewise.
444
445         * config/i386/i386.c (ix86_builtins): Add IX86_BUILTIN_MOVNTDQ256,
446         IX86_BUILTIN_MOVNTPD256 and IX86_BUILTIN_MOVNTPS256.
447         (ix86_special_builtin_type): Add VOID_FTYPE_PV4DI_V4DI.
448         (bdesc_special_args): Add __builtin_ia32_movntdq256,
449         __builtin_ia32_movntpd256 and __builtin_ia32_movntps256.
450         (ix86_init_mmx_sse_builtins): Handle VOID_FTYPE_PV4DI_V4DI.
451         (ix86_expand_special_args_builtin): Likewise.
452
453         * config/i386/sse.md (AVXMODEDI): New.
454         (avx_movnt<mode>): Likewise.
455         (avx_movnt<mode>): Likewise.
456         (<sse>_movnt<mode>): Remove AVX support.
457         (sse2_movntv2di): Likewise.
458
459 2009-01-07  Richard Guenther  <rguenther@suse.de>
460
461         PR middle-end/38751
462         * fold-const.c (extract_muldiv): Remove obsolete comment.
463         (fold_plusminus_mult_expr): Undo MINUS_EXPR
464         to PLUS_EXPR canonicalization for the canonicalization.
465
466 2009-01-07  Gerald Pfeifer  <gerald@pfeifer.com>
467
468         * doc/install.texi (alpha*-dec-osf*): Remove note on 32-bit
469         hosted cross-compilers generating less efficient code.
470
471 2009-01-06  Richard Sandiford  <rdsandiford@googlemail.com>
472
473         * function.h (rtl_data): Add a dbr_scheduled_p field.
474         * reorg.c (dbr_schedule): Set it.
475         (gate_handle_delay_slots): Check it.
476         * config/mips/mips.c (mips_base_delayed_branch): Delete.
477         (mips_reorg): Check flag_delayed_branch instead of
478         mips_base_delayed_branch.
479         (mips_override_options): Don't set mips_base_delayed_branch
480         or flag_delayed_branch.
481
482 2009-01-06  Richard Sandiford  <rdsandiford@googlemail.com>
483
484         PR rtl-optimization/38426.
485         * ira.c (ira): Set current_function_is_leaf earlier.
486
487 2009-01-06  Jakub Jelinek  <jakub@redhat.com>
488
489         PR rtl-optimization/38722
490         * combine.c (try_combine): Don't modify PATTERN (i3) and notes
491         too early, only set a flag and modify after last possible
492         undo_all point.
493
494 2009-01-06  Janis Johnson  <janis187@us.ibm.com>
495
496         PR c/34252
497         * ginclude/float.h: Rename DECnn_DEN to DECnn_SUBNORMAL_MIN.
498         * real.c (decimal_single_format): Correct values of emin and emax.
499         (decimal_double_format): Ditto.
500         (decimal_quad_format): Ditto.
501         * c-cppbuiltin.c (builtin_define_decimal_float_constants): Adjust
502         computation of DECnn_MIN and DECnn_MAX for corrected values of
503         emin and emax.  Define __DECnn_SUBNORMAL_MIN__ instead of
504         __DECnn_MIN__, and adjust its computation for the corrected value
505         of emin.
506
507 2009-01-06  Jan Hubicka  <jh@suse.cz>
508
509         PR target/38744
510         * i386.c (ix86_expand_call): Use ARRAY_SIZE.
511
512 2009-01-06  Gerald Pfeifer  <gerald@pfeifer.com>
513
514         * doc/contrib.texi (Contributors): Slightly adjust the end note.
515         Add Robert Clark to the list of testers.
516
517 2009-01-06  Jan Hubicka  <jh@suse.cz>
518             Kai Tietz <kai.tietz@onevision.com>
519
520         * i386.md (*msabi_syvabi): Add SSE regs clobbers.
521         * i386.c (ix86_expand_call): Add clobbers.
522
523 2009-01-06  Jan Hubicka  <jh@suse.cz>
524             Kai Tietz <kai.tietz@onevision.com>
525
526         * i386.h (CONDITIONAL_CALL_USAGE): SSE regs are not used for w64 ABI.
527         * i386.c (struct ix86_frame): Add padding0 and nsseregs.
528         (ix86_nsaved_regs): Count only general purpose regs.
529         (ix86_nsaved_sseregs): New.
530         (ix86_compute_frame_layout): Update nsseregs; set preferred alignment
531         to 16 for w64; compute padding and size of sse reg save area.
532         (ix86_emit_save_regs, ix86_emit_save_regs_using_mov): Save only
533         general purpose regs.
534         (ix86_emit_save_sse_regs_using_mov): New.
535         (ix86_expand_prologue): Save SSE regs if needed.
536         (ix86_emit_restore_regs_using_mov): Use only general purpose regs.
537         (ix86_emit_restore_sse_regs_using_mov): New.
538         (ix86_expand_epilogue): Save SSE regs if needed.
539
540 2009-01-06  Jan Hubicka  <jh@suse.cz>
541             Kai Tietz <kai.tietz@onevision.com>
542
543         * i386.h (ACCUMULATE_OUTGOING_ARGS): Enable for MSABI
544         * i386.c (init_cumulative_args): Disallow calls of MSABI functions
545         when accumulate outgoing args is off.
546
547 2009-01-06  H.J. Lu  <hongjiu.lu@intel.com>
548
549         PR bootstrap/38742
550         * ira-color.c (ira_reuse_stack_slot): Check ENABLE_IRA_CHECKING
551         before using pseudos_have_intersected_live_ranges_p.
552
553         * ira-int.h (ira_assert): Always define.
554
555 2009-01-06  H.J. Lu  <hongjiu.lu@intel.com>
556
557         AVX Programming Reference (December, 2008)
558         * config/i386/avxintrin.h (_mm_permute2_pd): Removed.
559         (_mm256_permute2_pd): Likewise.
560         (_mm_permute2_ps): Likewise.
561         (_mm256_permute2_ps): Likewise.
562         * config/i386/i386.md (UNSPEC_VPERMIL2): Likewise.
563         * config/i386/sse.md (avx_vpermil2<mode>3): Likewise.
564
565         * config/i386/i386.c (ix86_builtins): Remove
566         IX86_BUILTIN_VPERMIL2PD, IX86_BUILTIN_VPERMIL2PS,
567         IX86_BUILTIN_VPERMIL2PD256 and IX86_BUILTIN_VPERMIL2PS256.
568         (ix86_builtin_type): Remove V8SF_FTYPE_V8SF_V8SF_V8SI_INT,
569         V4DF_FTYPE_V4DF_V4DF_V4DI_INT, V4SF_FTYPE_V4SF_V4SF_V4SI_INT
570         and V2DF_FTYPE_V2DF_V2DF_V2DI_INT.
571         (bdesc_args): Remove __builtin_ia32_vpermil2pd,
572         __builtin_ia32_vpermil2ps, __builtin_ia32_vpermil2pd256 and
573         __builtin_ia32_vpermil2ps256.
574         (ix86_init_mmx_sse_builtins): Updated.
575         (ix86_expand_args_builtin): Likewise.
576
577 2009-01-05  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
578
579         * pa.c (output_call): Relocate non-jump insns in the delay slot of
580         long absolute calls when generating PA 2.0 code.
581
582 2009-01-05  Vladimir Makarov  <vmakarov@redhat.com>
583
584         PR rtl-optimization/38583
585         * params.h (IRA_MAX_CONFLICT_TABLE_SIZE): New macro.
586
587         * params.def (ira-max-conflict-table-size): New.
588
589         * doc/invoke.texi (ira-max-conflict-table-size): Decribe.
590         
591         * ira.h (ira_conflicts_p): New external definition.
592         
593         * ira-conflicts.c (build_conflict_bit_table): Do not build too big
594         table.  Report this.  Return result of building.
595         (ira_build_conflicts): Use ira_conflicts_p.  Check result of
596         building conflict table.
597
598         * ira-color.c (fast_allocation): Use num instead of ira_allocnos_num.
599         (ira_color): Use ira_conflicts_p.
600         
601         * global.c: Include ira.h.
602         (pseudo_for_reload_consideration_p, build_insn_chain): Use
603         ira_conflicts_p.
604
605         * Makefile.in (global.o): Add ira.h.
606         
607         * ira-build.c (mark_all_loops_for_removal,
608         propagate_some_info_from_allocno): New.
609         (remove_unnecessary_allocnos): Call
610         propagate_some_info_from_allocno.
611         (remove_low_level_allocnos): New.
612         (remove_unnecessary_regions): Add parameter.  Call
613         mark_all_loops_for_removal and remove_low_level_allocnos.  Pass
614         parameter to remove_unnecessary_regions.
615         (ira_build): Remove all regions but root if the conflict table was
616         not built.  Update conflict hard regs for allocnos crossing calls.
617
618         * ira.c (ira_conflicts_p): New global.
619         (ira): Define and use ira_conflicts_p.
620
621         * reload1.c (compute_use_by_pseudos, reload, count_pseudo,
622         count_spilled_pseudo, find_reg, alter_reg, finish_spills,
623         emit_input_reload_insns, delete_output_reload): Use ira_conflicts_p.
624         
625 2009-01-06  Ben Elliston  <bje@au.ibm.com>
626
627         * gengtype-lex.l (YY_NO_INPUT): Define.
628
629 2009-01-05  Andrew Pinski  <andrew_pinski@playstation.sony.com>
630
631         PR c/34911
632         * c-common.c (handle_vector_size_attribute): Also reject
633         BOOLEAN_TYPE types.
634
635 2009-01-05  Sebastian Pop  <sebastian.pop@amd.com>
636
637         PR tree-optimization/38492
638         * graphite.c (rename_map_elt, debug_rename_elt,
639         debug_rename_map_1, debug_rename_map, new_rename_map_elt,
640         rename_map_elt_info, eq_rename_map_elts,
641         get_new_name_from_old_name, bb_in_sese_p): Moved around.
642         (sese_find_uses_to_rename_use): Renamed sese_build_livein_liveouts_use.
643         (sese_find_uses_to_rename_bb): Renamed sese_build_livein_liveouts_bb.
644         (sese_build_livein_liveouts): New.
645         (new_sese, free_sese): New.
646         (new_scop): Call new_sese.
647         (free_scop): Call free_sese.
648         (rename_variables_from_edge, rename_phis_end_scop): Removed.
649         (register_old_new_names): Renamed register_old_and_new_names.
650         (register_scop_liveout_renames, add_loop_exit_phis,
651         insert_loop_close_phis, struct igp,
652         default_liveout_before_guard, add_guard_exit_phis,
653         insert_guard_phis, copy_renames): New.
654         (translate_clast): Call insert_loop_close_phis and insert_guard_phis.
655         (sese_add_exit_phis_edge): Renamed scop_add_exit_phis_edge.
656         (rewrite_into_sese_closed_ssa): Renamed scop_insert_phis_for_liveouts.
657         (scop_adjust_phis_for_liveouts): New.
658         (gloog): Call scop_adjust_phis_for_liveouts.
659
660         * graphite.h (struct sese): Documented.  Added fields liveout,
661         num_ver and livein.
662         (SESE_LIVEOUT, SESE_LIVEIN, SESE_LIVEIN_VER, SESE_NUM_VER): New.
663         (new_sese, free_sese, sese_build_livein_liveouts): Declared.
664         (struct scop): Added field liveout_renames.
665         (SCOP_LIVEOUT_RENAMES): New.
666
667 2009-01-05  Harsha Jagasia  <harsha.jagasia@amd.com>
668
669         PR tree-optimization/38510
670         * graphite.c (recompute_all_dominators): Call mark_irreducible_loops.
671         (translate_clast): Call recompute_all_dominators before
672         graphite_verify.
673         (gloog): Call recompute_all_dominators before graphite_verify.
674
675 2009-01-05  Harsha Jagasia  <harsha.jagasia@amd.com>
676             Jan Sjodin <jan.sjodin@amd.com>
677
678         PR tree-optimization/38500
679         * graphite.c (create_sese_edges): Call fix_loop_structure after
680         splitting blocks.
681
682 2009-01-05  Joel Sherrill <joel.sherrill@oarcorp.com>
683
684         * config.gcc: Add m32r*-*-rtems*.
685         * config/m32r/rtems.h: New file.
686
687 2009-01-05  Ben Elliston  <bje@au.ibm.com>
688
689         * Makefile.in (.po.gmo): Use mkinstalldirs, not test -d || mkdir.
690         (.po.pox): Likewise.
691         (po/gcc.pot): Likewise.
692
693 2009-01-04  David S. Miller  <davem@davemloft.net>
694
695         * config/sparc/sparc.h (SECONDARY_MEMORY_NEEDED_RTX): Delete.
696         (STARTING_FRAME_OFFSET): Always set to zero.
697
698 2009-01-04  Richard Sandiford  <rdsandiford@googlemail.com>
699
700         * tree.def (LSHIFT_EXPR, RSHIFT_EXPR): Add commentary.
701         * tree-cfg.c (verify_gimple_assign_binary): Allow shifts of
702         fixed-point types, and vectors of the same.
703
704 2009-01-04  Richard Sandiford  <rdsandiford@googlemail.com>
705
706         * config/mips/sync.md (*mb_barrier): Rename to...
707         (*memory_barrier): ...this.
708
709 2009-01-04  Jonathan Wakely  <jwakely.gcc@gmail.com>
710
711         * doc/extend.texi (Function Attributes): Move @cindex after @item
712         for 'artificial' and 'flatten'. Fix grammar for 'externally_visible'
713         and put in alphabetical order. Fix 'target' name and put in order.
714         * doc/invoke.texi (-Wstrict-null-sentinel, -fipa-matrix-reorg): Fix
715         typos.
716
717 2009-01-04  Uros Bizjak  <ubizjak@gmail.com>
718
719         * config/s390/s390.md (UNSPEC_MB): Rename from UNSPECV_MB.
720         (memory_barrier): Expand as unspec instead of unspec_volatile.
721         Remove mem:BLK from insn operands.  Use Pmode scratch register.
722         (*memory_barrier): Define as unspec instead of unspec_volatile.
723         Use (match_dup 0) as input operand.
724
725         * config/sparc/sparc.md (UNSPEC_MEMBAR): Rename from UNSPECV_MEMBAR.
726         * config/sparc/sync.md (memory_barrier): Expand as unspec instead of
727         unspec_volatile.  Remove mem:BLK from insn operands.  Use Pmode
728         scratch register.  Remove operand 1.
729         (*stbar): Define as unspec instead of unspec_volatile.
730         Use (match_dup 0) as input operand, remove (const_int 8).
731         (*membar): Define as unspec instead of unspec_volatile.
732         Use (match_dup 0) as input operand, remove input operand 2.
733
734         * config/xtensa/xtensa.md (UNSPEC_MEMW): Rename from UNSPECV_MEMW.
735         (memory_barrier): Expand as unspec instead of unspec_volatile.
736         Remove mem:BLK from insn operands.  Use Pmode scratch register.
737         (*memory_barrier): Define as unspec instead of unspec_volatile.
738         Use (match_dup 0) as input operand.
739
740         * config/ia64/sync.md (memory_barrier): Redefine as expander pattern.
741         Remove mem:BLK from insn operands.  Use Pmode scratch register.
742         Set volatile flag on operand 0.
743         (*memory_barrier): New insn pattern.
744
745         * config/rs6000/sync.md (memory_barrier): Remove mem:BLK from
746         insn operands.
747         (*memory_barrier): Use (match_dup 0) as input operand.
748
749         * config/mips/sync.md (memory_barrier): Redefine as expander pattern.
750         Remove mem:BLK from insn operands.  Use Pmode scratch register.
751         Set volatile flag on operand 0.
752         (*mb_internal): New insn pattern.
753
754         * config/alpha/sync.md (*memory_barrier): Rename from *mb_internal.
755
756 2009-01-04  Steven Bosscher  <steven@gcc.gnu.org>
757
758         PR middle-end/38586
759         * function.c (struct temp_slot): Move to the section of the file
760         that deals with temp slots.  Remove field 'address'.
761         (temp_slot_address_table): New hash table of address -> temp slot.
762         (struct temp_slot_address_entry): New struct, items for the table.
763         (temp_slot_address_compute_hash, temp_slot_address_hash,
764         temp_slot_address_eq, insert_temp_slot_address): Support functions
765         for the new table.
766         (find_temp_slot_from_address): Rewrite to use the new hash table.
767         (remove_unused_temp_slot_addresses): Remove addresses of temp
768         slots that have been made available.
769         (remove_unused_temp_slot_addresses_1): Call-back for htab_traverse,
770         worker function for remove_unused_temp_slot_addresses.
771         (assign_stack_temp_for_type): Don't clear the temp slot address list.
772         Add the temp slot address to the address -> temp slot map.
773         (update_temp_slot_address): Update via insert_temp_slot_address.
774         (free_temp_slots): Call remove_unused_temp_slot_addresses.
775         (pop_temp_slots): Likewise.
776         (init_temp_slots): Allocate the address -> temp slot map, or empty
777         the map if it is already allocated.
778         (prepare_function_start): Initialize temp slot processing.
779
780 2009-01-04  Steven Bosscher  <steven@gcc.gnu.org>
781
782         PR middle-end/38584
783         * cfgexpand.c (estimate_stack_frame_size): Simplify the estimate:
784         Calculate the size of all stack vars assuming no packing of stack
785         vars will happen, replacing a quadratic algorithm with a linear one.
786
787 2009-01-03  Jakub Jelinek  <jakub@redhat.com>
788
789         PR target/38707
790         * expmed.c (store_bit_field_1): Don't modify op0 if movstrict insn
791         can't be used.
792
793 2009-01-03  Diego Novillo  <dnovillo@google.com>
794
795         * doc/contrib.texi: Update contributions.
796
797 2009-01-03  Jakub Jelinek  <jakub@redhat.com>
798
799         PR c++/38705
800         * builtins.c (fold_builtin_memory_op): Give up if either operand
801         is volatile.  Set srctype or desttype to non-qualified version
802         of the other type.
803
804         PR c/38700
805         * builtins.c (fold_builtin_expect): Only check DECL_WEAK for VAR_DECLs
806         and FUNCTION_DECLs.
807
808 2009-01-02  Kenneth Zadeck <zadeck@naturalbridge.com>
809
810         PR rtl-optimization/35805
811         * df-problems.c (df_lr_finalize): Add recursive call to resolve lr
812         problem if fast dce is able to remove any instructions.
813         * dce.c (dce_process_block): Fix dump message.
814         
815 2009-01-02  Mark Mitchell  <mark@codesourcery.com>
816
817         PR 33649
818         * tree-ssa-pre.c (compute_antic): Correct loop bounds.
819
820 2009-01-02  Jakub Jelinek  <jakub@redhat.com>
821
822         PR middle-end/38690
823         * tree-flow.h (op_code_prio, op_prio): New prototypes.
824         * tree-pretty-print.c (op_code_prio): New function.
825         (op_prio): No longer static.  Use op_code_prio.
826         * gimple-pretty-print.c (dump_unary_rhs, dump_binary_rhs):
827         Use op_prio and op_code_prio to determine if () should be
828         printed around operand(s) or not.
829
830         * gimple-pretty-print.c (dump_unary_rhs, dump_binary_rhs,
831         dump_gimple_call, dump_gimple_switch, dump_gimple_cond,
832         dump_gimple_label, dump_gimple_try, dump_symbols, dump_gimple_phi,
833         dump_gimple_mem_ops, dump_bb_header, dump_bb_end, pp_cfg_jump): Use
834         pp_character instead of pp_string for single letter printing.
835
836 2009-01-02  Richard Sandiford  <rdsandiford@googlemail.com>
837
838         * doc/extend.texi: Fix '#pragma GCC option' typo.
839
840 2009-01-02 Richard Guenther <rguenther@suse.de>
841
842         * doc/install.texi (--enable-checking): Mention different
843         default for stage1.
844         (--enable-stage1-checking): Document.
845
846 2009-01-01  Andrew Pinski  <pinskia@gmail.com>
847
848         PR middle-end/30142
849         * tree-cfg.c (verify_expr): Add INDIRECT_REF case.  Change MODIFY_EXPR
850         case to be an error.
851
852 2009-01-02  Ben Elliston  <bje@au.ibm.com>
853
854         * config/fp-bit.h (pack_d): Constify argument.
855         * config/fp-bit.c (makenan): Constify return type. Remove casts.
856         (isnan): Constify argument.
857         (isinf): Likewise.
858         (iszero): Likewise.
859         (pack_d): Likewise.
860         (_fpadd_parts): Constify return type.
861         (_fpmul_parts): Likewise.
862         (_fpdiv_parts): Likewise.
863
864 2009-01-01  Jakub Jelinek  <jakub@redhat.com>
865
866         PR c/36489
867         * c-typeck.c (add_pending_init): Add IMPLICIT argument.  Only
868         warn about overwriting initializer with side-effects or
869         -Woverride-init if !IMPLICIT.
870         (output_init_element): Likewise.  Pass IMPLICIT down to
871         add_pending_init.
872         (process_init_element): Add IMPLICIT argument.  Pass it down
873         to output_init_element.
874         (push_init_element, pop_init_level, set_designator): Adjust
875         process_init_element callers.
876         (set_nonincremental_init, set_nonincremental_init_from_string):
877         Adjust add_pending_init callers.
878         (output_pending_init_elements): Adjust output_init_element callers.
879         * c-tree.h (process_init_element): Adjust prototype.
880         * c-parser.c (c_parser_initelt, c_parser_initval): Adjust
881         process_init_element callers.