1. 15 Feb, 2016 5 commits
    • S/390: Add -fsplit-stack support · 4cb4721f
      libgcc/ChangeLog:
      
      	* config.host: Use t-stack and t-stack-s390 for s390*-*-linux.
      	* config/s390/morestack.S: New file.
      	* config/s390/t-stack-s390: New file.
      	* generic-morestack.c (__splitstack_find): Add s390-specific code.
      
      gcc/ChangeLog:
      
      	* common/config/s390/s390-common.c (s390_supports_split_stack):
      	New function.
      	(TARGET_SUPPORTS_SPLIT_STACK): New macro.
      	* config/s390/s390-protos.h: Add s390_expand_split_stack_prologue.
      	* config/s390/s390.c (struct machine_function): New field
      	split_stack_varargs_pointer.
      	(s390_register_info): Mark r12 as clobbered if it'll be used as temp
      	in s390_emit_prologue.
      	(s390_emit_prologue): Use r12 as temp if r1 is taken by split-stack
      	vararg pointer.
      	(morestack_ref): New global.
      	(SPLIT_STACK_AVAILABLE): New macro.
      	(s390_expand_split_stack_prologue): New function.
      	(s390_live_on_entry): New function.
      	(s390_va_start): Use split-stack vararg pointer if appropriate.
      	(s390_asm_file_end): Emit the split-stack note sections.
      	(TARGET_EXTRA_LIVE_ON_ENTRY): New macro.
      	* config/s390/s390.md (UNSPEC_STACK_CHECK): New unspec.
      	(UNSPECV_SPLIT_STACK_CALL): New unspec.
      	(UNSPECV_SPLIT_STACK_DATA): New unspec.
      	(split_stack_prologue): New expand.
      	(split_stack_space_check): New expand.
      	(split_stack_data): New insn.
      	(split_stack_call): New expand.
      	(split_stack_call_*): New insn.
      	(split_stack_cond_call): New expand.
      	(split_stack_cond_call_*): New insn.
      
      From-SVN: r233421
      Marcin Kościelnicki committed
    • re PR tree-optimization/69783 (Loop is not vectorized after r233212) · 17a3b967
      2016-02-15  Richard Biener  <rguenther@suse.de>
      
      	PR tree-optimization/69783
      	* tree-vect-data-refs.c (vect_prune_runtime_alias_test_list):
      	Add trivially correct cases.
      
      	* gcc.dg/vect/pr69783.c: New testcase.
      
      From-SVN: r233420
      Richard Biener committed
    • Don't mark offload symbols with force_output in ltrans · ed5d948d
      2016-02-15  Tom de Vries  <tom@codesourcery.com>
      
      	PR lto/69655
      	* lto-cgraph.c (input_offload_tables): Add and handle bool parameter
      	do_force_output.
      	* lto-streamer.h (input_offload_tables): Add and handle bool parameter.
      
      	* lto.c (read_cgraph_and_symbols): Call input_offload_tables with
      	argument.
      
      From-SVN: r233419
      Tom de Vries committed
    • re PR tree-optimization/69776 (Wrong optimization with aliasing) · 1c48bff1
      2016-02-15  Richard Biener  <rguenther@suse.de>
      
      	PR tree-optimization/69776
      	* tree-ssa-sccvn.h (vn_reference_lookup): Adjust prototype.
      	* tree-ssa-sccvn.c (vn_reference_lookup): Add parameter to
      	indicate whether we can use TBAA to disambiguate against stores.
      	Use alias-set zero if not.
      	(visit_reference_op_store): Do not use TBAA when looking up
      	redundant stores.
      	* tree-ssa-pre.c (compute_avail): Use TBAA here.
      	(eliminate_dom_walker::before_dom_children): But not when looking
      	up redundant stores.
      
      	* gcc.dg/torture/pr69776.c: New testcase.
      
      From-SVN: r233418
      Richard Biener committed
    • Daily bump. · 9e074c0d
      From-SVN: r233417
      GCC Administrator committed
  2. 14 Feb, 2016 10 commits
  3. 13 Feb, 2016 5 commits
  4. 12 Feb, 2016 20 commits
    • runtime: For c-archive/c-shared, install signal handlers synchronously. · 54c9c975
          
          This is a port of https://golang.org/cl/18150 to the gccgo runtime.
          
          The previous behaviour of installing the signal handlers in a separate
          thread meant that Go initialization raced with non-Go initialization if
          the non-Go initialization also wanted to install signal handlers.  Make
          installing signal handlers synchronous so that the process-wide behavior
          is predictable.
          
          Reviewed-on: https://go-review.googlesource.com/19494
      
      From-SVN: r233393
      Ian Lance Taylor committed
    • * eo.po: Update. · 37064e3d
      From-SVN: r233392
      Joseph Myers committed
    • t-tilepro: Replace CC_FOR_BUILD with CXX_FOR_BUILD. · 77602f8b
      gcc/ChangeLog:
              * config/tilepro/t-tilepro: Replace CC_FOR_BUILD with
                CXX_FOR_BUILD.
              * config/tilegx/t-tilegx: Likewise.
      
      From-SVN: r233390
      Walter Lee committed
    • config.host (tilegx*-*-linux*): remove ti from softfp_int_modes for 32-bit configs. · b29d9a29
      libgcc/ChangeLog:
              * config.host (tilegx*-*-linux*): remove ti from
                softfp_int_modes for 32-bit configs.
      
      From-SVN: r233389
      Walter Lee committed
    • re PR fortran/69668 (Error reading namelist opened with DELIM='NONE') · 7f4cc3ce
      2016-02-12  Jerry DeLisle  <jvdelisle@gcc.gnu.org>
      
      	PR libgfortran/69668
      	* gfortran.dg/namelist_88.f90: New test.
      
      From-SVN: r233388
      Jerry DeLisle committed
    • re PR fortran/69668 (Error reading namelist opened with DELIM='NONE') · 955ca6dc
      2016-02-12  Jerry DeLisle  <jvdelisle@gcc.gnu.org>
      
      	PR libgfortran/69668
      	* io/list_read.c (read_character): Remove code related to DELIM_NONE.
      
      	PR libgfortran/69668
      	* gfortran.dg/namelist_38.f90: Update test.
      	* gfortran.dg/namelist_84.f90: Update test.
      
      From-SVN: r233387
      Jerry DeLisle committed
    • PR other/69554: avoid excessive source printing for widely-separated locations · 876217ae
      gcc/ChangeLog:
      	PR other/69554
      	* diagnostic-show-locus.c (struct line_span): New struct.
      	(layout::get_first_line): Delete.
      	(layout::get_last_line): Delete.
      	(layout::get_num_line_spans): New member function.
      	(layout::get_line_span): Likewise.
      	(layout::print_heading_for_line_span_index_p): Likewise.
      	(layout::get_expanded_location): Likewise.
      	(layout::calculate_line_spans): Likewise.
      	(layout::m_first_line): Delete.
      	(layout::m_last_line): Delete.
      	(layout::m_line_spans): New field.
      	(layout::layout): Update comment.  Replace m_first_line and
      	m_last_line with m_line_spans, replacing their initialization
      	with a call to calculate_line_spans.
      	(diagnostic_show_locus): When printing source lines and
      	annotations, rather than looping over a single span
      	of lines, instead loop over each line_span within
      	the layout, with an inner loop over the lines within them.
      	Call the context's start_span callback when changing line spans.
      	* diagnostic.c (diagnostic_initialize): Initialize start_span.
      	(diagnostic_build_prefix): Break out the building of the location
      	part of the string into...
      	(diagnostic_get_location_text): ...this new function, rewriting
      	it from nested ternary expressions to a sequence of "if"
      	statements.
      	(default_diagnostic_start_span_fn): New function.
      	* diagnostic.h (diagnostic_start_span_fn): New typedef.
      	(diagnostic_context::start_span): New field.
      	(default_diagnostic_start_span_fn): New prototype.
      
      gcc/fortran/ChangeLog:
      	PR other/69554
      	* error.c (gfc_diagnostic_start_span): New function.
      	(gfc_diagnostics_init): Initialize global_dc's start_span.
      
      gcc/testsuite/ChangeLog:
      	PR other/69554
      	* gcc.dg/pr69554-1.c: New test.
      	* gfortran.dg/pr69554-1.F90: New test.
      	* gfortran.dg/pr69554-2.F90: New test.
      	* lib/gcc-dg.exp (proc dg-locus): New function.
      	* lib/gfortran-dg.exp (proc gfortran-dg-test): Update comment to
      	distinguish between the caret-printing and non-caret-printing
      	cases.  If caret-printing has been explicitly enabled, bail out
      	without attempting to fix up the output.
      
      From-SVN: r233386
      David Malcolm committed
    • PR driver/69779: fix bogus cleanup code used by libgccjit affecting s390x · 8dccd19b
      gcc/ChangeLog:
      	PR driver/69779
      	* gcc.c (driver::finalize): Fix cleanup of "specs".
      
      From-SVN: r233385
      David Malcolm committed
    • PR driver/69265 and 69453: improved suggestions for various misspelled options · 61789eed
      gcc/ChangeLog:
      	PR driver/69265
      	PR driver/69453
      	* gcc.c (driver::driver): Initialize m_option_suggestions.
      	(driver::~driver): Clean up m_option_suggestions.
      	(suggest_option): Convert to...
      	(driver::suggest_option): ...this, and split out into
      	driver::build_option_suggestions and find_closest_string.
      	(driver::build_option_suggestions): New function, from
      	first half of suggest_option.  Special-case
      	OPT_fsanitize_ and OPT_fsanitize_recover_, making use of
      	the sanitizer_opts array.  For options of enum types, add the
      	various enum values to the candidate strings.
      	(driver::handle_unrecognized_options): Remove "const".
      	* gcc.h (driver::handle_unrecognized_options): Likewise.
      	(driver::build_option_suggestions): New decl.
      	(driver::suggest_option): New decl.
      	(driver::m_option_suggestions): New field.
      	* opts-common.c (add_misspelling_candidates): New function.
      	* opts.c (sanitizer_opts): Remove decl of struct sanitizer_opts_s
      	and make non-static.
      	* opts.h (sanitizer_opts): New array decl.
      	(add_misspelling_candidates): New function decl.
      	* spellcheck.c (find_closest_string): New function.
      	* spellcheck.h (find_closest_string): New function decl.
      
      gcc/testsuite/ChangeLog:
      	PR driver/69265
      	PR driver/69453
      	* gcc.dg/spellcheck-options-3.c: New test case.
      	* gcc.dg/spellcheck-options-4.c: New test case.
      	* gcc.dg/spellcheck-options-5.c: New test case.
      	* gcc.dg/spellcheck-options-6.c: New test case.
      	* gcc.dg/spellcheck-options-7.c: New test case.
      	* gcc.dg/spellcheck-options-8.c: New test case.
      	* gcc.dg/spellcheck-options-9.c: New test case.
      	* gcc.dg/spellcheck-options-10.c: New test case.
      
      From-SVN: r233382
      David Malcolm committed
    • re PR rtl-optimization/69764 (ICE on x86_64-linux-gnu at -O0 (in decompose, at rtl.h:2107)) · c3090c1f
      	PR rtl-optimization/69764
      	PR rtl-optimization/69771
      	* optabs.c (expand_binop_directly): For shift_optab_p, force
      	convert_modes with VOIDmode if xop1 has VOIDmode.
      
      	* c-c++-common/pr69764.c: New test.
      	* gcc.dg/torture/pr69771.c: New test.
      
      From-SVN: r233381
      Jakub Jelinek committed
    • * g++.dg/torture/init-list1.C: New. · 8222034d
      From-SVN: r233380
      Marek Polacek committed
    • * gcc.dg/pr69522.c: Add empty dg-options. · f749f792
      From-SVN: r233377
      Marek Polacek committed
    • re PR middle-end/69729 ([CHKP] internal compiler error: Segmentation fault) · 199fb02a
      gcc/
      
      	PR target/69729
      	* lto-streamer-out.c (lto_output): Use thunk.add_pointer_bounds_args
      	to correctly determine instrumentation thunks.
      
      gcc/testsuite/
      
      	* g++.dg/lto/lto.exp: Include and init mpx.
      	* g++.dg/lto/pr69729_0.C: New test.
      
      From-SVN: r233376
      Ilya Enkovich committed
    • re PR ipa/69241 (ICE with noreturn and function that return non-POD) · 06ff7000
      	PR ipa/69241
      	* ipa-split.c (split_function): If split part returns TREE_ADDRESSABLE
      	type by reference, force lhs on the call.
      
      	* g++.dg/ipa/pr69241-4.C: New test.
      
      From-SVN: r233375
      Jakub Jelinek committed
    • re PR ipa/68672 (g++.dg/torture/pr68470.C: ICE: cannot update SSA form:… · b69539cb
      re PR ipa/68672 (g++.dg/torture/pr68470.C: ICE: cannot update SSA form: statement uses released SSA name)
      
      	PR ipa/68672
      	* ipa-split.c (split_function): Don't compute/use main_part_return_p.
      	Compute retval and retbnd early in all cases if split_part_return_p
      	and return_bb is not EXIT.  Remove all clobber stmts and reset
      	all debug stmts that refer to SSA_NAMEs defined in split part,
      	except if it is retval, in that case replace the old retval with the
      	lhs of the call to the split part.
      
      	* g++.dg/ipa/pr68672-1.C: New test.
      	* g++.dg/ipa/pr68672-2.C: New test.
      	* g++.dg/ipa/pr68672-3.C: New test.
      
      From-SVN: r233374
      Jakub Jelinek committed
    • revert: re PR tree-optimization/66726 (missed optimization, factor conversion out of COND_EXPR) · 4c707980
      2016-02-12  Kugan Vivekanandarajah  <kuganv@linaro.org>
      
      	revert:
      	2016-02-12  Kugan Vivekanandarajah  <kuganv@linaro.org>
      
      	PR middle-end/66726
      	* tree-ssa-reassoc.c (optimize_range_tests): Handle tcc_compare stmt
      	whose result is used in PHI.
      	(maybe_optimize_range_tests): Likewise.
      	(final_range_test_p): Likweise.
      
      From-SVN: r233368
      Kugan Vivekanandarajah committed
    • Fix incomplete initialization of the declspec struct. · f48dfe98
      	* c-decl.c (build_null_declspecs): Zero the entire struct.
      
      From-SVN: r233367
      Bernd Schmidt committed
    • Fix obstack use-after-free problems in C frontend, PR69522 · 16595a1f
      c/
      	PR c/69522
      	* c-parser.c (c_parser_braced_init): New arg outer_obstack.  All
      	callers changed.  If nested_p is true, use it to call
      	finish_implicit_inits.
      	* c-tree.h (finish_implicit_inits): Declare.
      	* c-typeck.c (finish_implicit_inits): New function.  Move code
      	from ...
      	(push_init_level): ... here.
      	(set_designator, process_init_element): Call finish_implicit_inits.
      
      testsuite/
      	PR c/69522
      	gcc.dg/pr69522.c: New test.
      
      From-SVN: r233366
      Bernd Schmidt committed
    • Fix PR c++/69098 (bogus errors with static data member template) · 38d795d2
      gcc/cp/ChangeLog:
      
      	PR c++/69098
      	* pt.c (lookup_and_finish_template_variable): New function,
      	extracted from ...
      	(tsubst_copy_and_build) [TEMPLATE_ID_EXPR]: ... here.
      	(tsubst_qualified_id): Consider that EXPR might be a variable
      	template.
      	* typeck.c (check_template_keyword): Don't emit an error
      	if DECL is a variable template.
      
      gcc/testsuite/ChangeLog:
      
      	PR c++/69098
      	* g++.dg/cpp1y/69098.C: New test.
      	* g++.dg/cpp1y/69098-2.C: New test.
      
      From-SVN: r233365
      Patrick Palka committed