1. 04 Oct, 2018 21 commits
    • Report vectorization problems via a new opt_problem class · f4ebbd24
      This is v3 of the patch; previous versions were:
        v2: https://gcc.gnu.org/ml/gcc-patches/2018-07/msg00446.html
        v1: https://gcc.gnu.org/ml/gcc-patches/2018-06/msg01462.html
      
      This patch introduces a class opt_problem, along with wrapper
      classes for bool (opt_result) and for pointers (e.g. opt_loop_vec_info
      for loop_vec_info).
      
      opt_problem instances are created when an optimization problem
      is encountered, but only if dump_enabled_p.  They are manually
      propagated up the callstack, and are manually reported at the
      "top level" of an optimization if dumping is enabled, to give the user
      a concise summary of the problem *after* the failure is reported.
      In particular, the location of the problematic statement is
      captured and emitted, rather than just the loop's location.
      
      For example:
      
      no-vfa-vect-102.c:24:3: missed: couldn't vectorize loop
      no-vfa-vect-102.c:27:7: missed: statement clobbers memory: __asm__ __volatile__("" :  :  : "memory");
      
      Changed in v3:
      * This version bootstraps and passes regression testing (on
        x86_64-pc-linux-gnu).
      * added selftests, to exercise the opt_problem machinery
      * removed the "bool to opt_result" ctor, so that attempts to
        use e.g. return a bool from an opt_result-returning function
        will fail at compile time
      * use formatted printing within opt_problem ctor to replace the
        various dump_printf_loc calls
      * dropped i18n
      * changed the sense of vect_analyze_data_ref_dependence's return
        value (see the ChangeLog)
      * add MSG_PRIORITY_REEMITTED, so that -fopt-info can show the
        messages, without them messing up the counts in scan-tree-dump-times
        in DejaGnu tests
      
      gcc/ChangeLog:
      	* Makefile.in (OBJS): Add opt-problem.o.
      	* dump-context.h: Include "selftest.h.
      	(selftest::temp_dump_context): New forward decl.
      	(class dump_context): Make friend of class
      	selftest::temp_dump_context.
      	(dump_context::dump_loc_immediate): New decl.
      	(class dump_pretty_printer): Move here from dumpfile.c.
      	(class temp_dump_context): Move to namespace selftest.
      	(temp_dump_context::temp_dump_context): Add param
      	"forcibly_enable_dumping".
      	(selftest::verify_dumped_text):
      	(ASSERT_DUMPED_TEXT_EQ): Move here from dumpfile.c.
      	(selftest::verify_item):
      	(ASSERT_IS_TEXT): Move here from dumpfile.c.
      	(ASSERT_IS_TREE): Likewise.
      	(ASSERT_IS_GIMPLE): Likewise.
      	* dumpfile.c (dump_context::dump_loc): Move immediate dumping
      	to...
      	(dump_context::dump_loc_immediate): ...this new function.
      	(class dump_pretty_printer): Move to dump-context.h.
      	(dump_switch_p_1): Don't enable MSG_PRIORITY_REEMITTED.
      	(opt_info_switch_p_1): Enable MSG_PRIORITY_REEMITTED.
      	(temp_dump_context::temp_dump_context): Move to "selftest"
      	namespace.  Add param "forcibly_enable_dumping", and use it to
      	conditionalize the use of m_pp;
      	(selftest::verify_dumped_text): Make non-static.
      	(ASSERT_DUMPED_TEXT_EQ): Move to dump-context.h.
      	(selftest::verify_item): Make non-static.
      	(ASSERT_IS_TEXT): Move to dump-context.h.
      	(ASSERT_IS_TREE): Likewise.
      	(ASSERT_IS_GIMPLE): Likewise.
      	(selftest::test_capture_of_dump_calls): Pass "true" for new
      	param of temp_dump_context.
      	* dumpfile.h (enum dump_flag): Add MSG_PRIORITY_REEMITTED, adding
      	it to MSG_ALL_PRIORITIES.  Update values of TDF_COMPARE_DEBUG and
      	TDF_COMPARE_DEBUG.
      	* opt-problem.cc: New file.
      	* opt-problem.h: New file.
      	* optinfo-emit-json.cc
      	(selftest::test_building_json_from_dump_calls): Pass "true" for
      	new param of temp_dump_context.
      	* optinfo.cc (optinfo_kind_to_dump_flag): New function.
      	(optinfo::emit_for_opt_problem): New function.
      	(optinfo::emit): Clarity which emit_item is used.
      	* optinfo.h (optinfo::get_dump_location): New accessor.
      	(optinfo::emit_for_opt_problem): New decl.
      	(optinfo::emit): Make const.
      	* selftest-run-tests.c (selftest::run_tests): Call
      	selftest::opt_problem_cc_tests.
      	* selftest.h (selftest::opt_problem_cc_tests): New decl.
      	* tree-data-ref.c (dr_analyze_innermost): Convert return type from
      	bool to opt_result, converting fprintf messages to
      	opt_result::failure_at calls.  Add "stmt" param for use by the
      	failure_at calls.
      	(create_data_ref): Pass "stmt" to the dr_analyze_innermost call.
      	(runtime_alias_check_p): Convert return type from bool to
      	opt_result, converting dump_printf calls to
      	opt_result::failure_at, using the statement DDR_A for their
      	location.
      	(find_data_references_in_stmt): Convert return type from bool to
      	opt_result, converting "return false" to opt_result::failure_at
      	with a new message.
      	* tree-data-ref.h: Include "opt-problem.h".
      	(dr_analyze_innermost): Convert return type from bool to opt_result,
      	and add a const gimple * param.
      	(find_data_references_in_stmt): Convert return type from bool to
      	opt_result.
      	(runtime_alias_check_p): Likewise.
      	* tree-predcom.c (find_looparound_phi): Pass "init_stmt" to
      	dr_analyze_innermost.
      	* tree-vect-data-refs.c (vect_mark_for_runtime_alias_test):
      	Convert return type from bool to opt_result, adding a message for
      	the PARAM_VECT_MAX_VERSION_FOR_ALIAS_CHECKS zero case.
      	(vect_analyze_data_ref_dependence): Convert return type from bool
      	to opt_result.  Change sense of return type from "false"
      	effectively meaning "no problems" to "false" meaning a problem,
      	so that "return false" becomes "return opt_result::success".
      	Convert "return true" calls to opt_result::failure_at, using
      	the location of statement A rather than vect_location.
      	(vect_analyze_data_ref_dependences): Convert return type from bool
      	to opt_result.
      	(verify_data_ref_alignment): Likewise, converting dump_printf_loc
      	calls to opt_result::failure_at, using the stmt location rather
      	than vect_location.
      	(vect_verify_datarefs_alignment): Convert return type from bool
      	to opt_result.
      	(vect_enhance_data_refs_alignment): Likewise.  Split local "stat"
      	into multiple more-tightly-scoped copies.
      	(vect_analyze_data_refs_alignment): Convert return type from bool
      	to opt_result.
      	(vect_analyze_data_ref_accesses): Likewise, converting a
      	"return false" to a "return opt_result::failure_at", adding a
      	new message.
      	(vect_prune_runtime_alias_test_list): Convert return type from
      	bool to opt_result, converting dump_printf_loc to
      	opt_result::failure_at.  Add a %G to show the pertinent statement,
      	and use the stmt's location rather than vect_location.
      	(vect_find_stmt_data_reference): Convert return type from
      	bool to opt_result, converting dump_printf_loc to
      	opt_result::failure_at, using stmt's location.
      	(vect_analyze_data_refs):  Convert return type from bool to
      	opt_result.  Convert "return false" to "return
      	opt_result::failure_at", adding messages as needed.
      	* tree-vect-loop.c (vect_determine_vf_for_stmt_1): Convert return
      	type from bool to opt_result.
      	(vect_determine_vf_for_stmt): Likewise.
      	(vect_determine_vectorization_factor): Likewise, converting
      	dump_printf_loc to opt_result::failure_at, using location of phi
      	rather than vect_location.
      	(vect_analyze_loop_form_1): Convert return type from bool to
      	opt_result, converting dump_printf_loc calls, retaining the use of
      	vect_location.
      	(vect_analyze_loop_form): Convert return type from loop_vec_info
      	to opt_loop_vec_info.
      	(vect_analyze_loop_operations): Convert return type from bool to
      	opt_result, converting dump_printf_loc calls, using the location
      	of phi/stmt rather than vect_location where available.  Convert
      	various "return false" to "return opt_result::failure_at" with
      	"unsupported phi" messages.
      	(vect_get_datarefs_in_loop): Convert return type from bool to
      	opt_result.  Add a message for the
      	PARAM_LOOP_MAX_DATAREFS_FOR_DATADEPS failure.
      	(vect_analyze_loop_2): Convert return type from bool to
      	opt_result.  Ensure "ok" is set to a opt_result::failure_at before
      	each "goto again;", adding new messages where needed.
      	Add "unsupported grouped {store|load}" messages.
      	(vect_analyze_loop): Convert return type from loop_vec_info to
      	opt_loop_vec_info.
      	* tree-vect-slp.c (vect_analyze_slp): Convert return type from
      	bool to opt_result.
      	* tree-vect-stmts.c (process_use): Likewise, converting
      	dump_printf_loc call and using stmt location, rather than
      	vect_location.
      	(vect_mark_stmts_to_be_vectorized): Likeise.
      	(vect_analyze_stmt): Likewise, adding a %G.
      	(vect_get_vector_types_for_stmt): Convert return type from bool to
      	opt_result, converting dump_printf_loc calls and using stmt
      	location, rather than vect_location.
      	(vect_get_mask_type_for_stmt): Convert return type from tree to
      	opt_tree, converting dump_printf_loc calls and using stmt location.
      	* tree-vectorizer.c: Include "opt-problem.h.
      	(try_vectorize_loop_1): Flag "Analyzing loop at" dump message as
      	MSG_PRIORITY_INTERNALS.  Convert local "loop_vinfo" from
      	loop_vec_info to opt_loop_vec_info.  If if fails, and dumping is
      	enabled, use it to report at the top level "couldn't vectorize
      	loop" followed by the problem.
      	* tree-vectorizer.h (opt_loop_vec_info): New typedef.
      	(vect_mark_stmts_to_be_vectorized): Convert return type from bool
      	to opt_result.
      	(vect_analyze_stmt): Likewise.
      	(vect_get_vector_types_for_stmt): Likewise.
      	(tree vect_get_mask_type_for_stmt): Likewise.
      	(vect_analyze_data_ref_dependences): Likewise.
      	(vect_enhance_data_refs_alignment): Likewise.
      	(vect_analyze_data_refs_alignment): Likewise.
      	(vect_verify_datarefs_alignment): Likewise.
      	(vect_analyze_data_ref_accesses): Likewise.
      	(vect_prune_runtime_alias_test_list): Likewise.
      	(vect_find_stmt_data_reference): Likewise.
      	(vect_analyze_data_refs): Likewise.
      	(vect_analyze_loop): Convert return type from loop_vec_info to
      	opt_loop_vec_info.
      	(vect_analyze_loop_form): Likewise.
      	(vect_analyze_slp): Convert return type from bool to opt_result.
      
      gcc/testsuite/ChangeLog:
      	* gcc.dg/vect/nodump-vect-opt-info-2.c: New test.
      	* gcc.dg/vect/vect-alias-check-4.c: Add "-fopt-info-vec-all" to
      	dg-additional-options.  Add dg-message and dg-missed directives
      	to verify that -fopt-info messages are written at the correct
      	locations.
      
      From-SVN: r264852
      David Malcolm committed
    • Add -fopt-info-internals · 7db960c5
      This patch introduces a verbosity level to dump messages:
      "user-facing" vs "internals".
      
      By default, messages at the top-level dump scope are "user-facing",
      whereas those that are in nested scopes are implicitly "internals",
      and are filtered out by -fopt-info unless a new "-internals" sub-option
      of "-fopt-info" is supplied (intended purely for use by GCC developers).
      Dumpfiles are unaffected by the change.
      
      Given that the vectorizer is the only subsystem using AUTO_DUMP_SCOPE
      (via DUMP_VECT_SCOPE), this only affects the vectorizer.
      
      Filtering out these implementation-detail messages goes a long way
      towards making -fopt-info-vec-all more accessible to advanced end-users;
      the follow-up patch restores the most pertinent missing details.
      
      gcc/ChangeLog:
      	* doc/invoke.texi (-fopt-info): Document new "internals"
      	sub-option.
      	* dump-context.h (dump_context::apply_dump_filter_p): New decl.
      	* dumpfile.c (dump_options): Update for renaming of MSG_ALL to
      	MSG_ALL_KINDS.
      	(optinfo_verbosity_options): Add "internals".
      	(kind_as_string): Update for renaming of MSG_ALL to MSG_ALL_KINDS.
      	(dump_context::apply_dump_filter_p): New member function.
      	(dump_context::dump_loc): Use apply_dump_filter_p rather than
      	explicitly masking the dump_kind.
      	(dump_context::begin_scope): Increment the scope depth first.  Use
      	apply_dump_filter_p rather than explicitly masking the dump_kind.
      	(dump_context::emit_item): Use apply_dump_filter_p rather than
      	explicitly masking the dump_kind.
      	(dump_dec): Likewise.
      	(dump_hex): Likewise.
      	(dump_switch_p_1): Default to MSG_ALL_PRIORITIES.
      	(opt_info_switch_p_1): Default to MSG_PRIORITY_USER_FACING.
      	(opt_info_switch_p): Update handling of default
      	MSG_OPTIMIZED_LOCATIONS to cope with default of
      	MSG_PRIORITY_USER_FACING.
      	(dump_basic_block): Use apply_dump_filter_p rather than explicitly
      	masking the dump_kind.
      	(selftest::test_capture_of_dump_calls): Update test_dump_context
      	instances to use MSG_ALL_KINDS | MSG_PRIORITY_USER_FACING rather
      	than MSG_ALL.  Generalize scope test to be run at all four
      	combinations of with/without MSG_PRIORITY_USER_FACING and
      	MSG_PRIORITY_INTERNALS, adding examples of explicit priority
      	for each of the two values.
      	* dumpfile.h (enum dump_flag): Add comment about the MSG_* flags.
      	Rename MSG_ALL to MSG_ALL_KINDS.  Add MSG_PRIORITY_USER_FACING,
      	MSG_PRIORITY_INTERNALS, and MSG_ALL_PRIORITIES, updating the
      	values for TDF_COMPARE_DEBUG and TDF_ALL_VALUES.
      	(AUTO_DUMP_SCOPE): Add a note to the comment about the interaction
      	with MSG_PRIORITY_*.
      	* tree-vect-loop-manip.c (vect_loop_versioning): Mark versioning
      	dump messages as MSG_PRIORITY_USER_FACING.
      	* tree-vectorizer.h (DUMP_VECT_SCOPE): Add a note to the comment
      	about the interaction with MSG_PRIORITY_*.
      
      gcc/testsuite/ChangeLog:
      	* gcc.dg/plugin/dump-1.c: Update expected output for test_scopes
      	due to "-internals" not being selected.
      	* gcc.dg/plugin/dump-2.c: New test, based on dump-1.c, with
      	"-internals" added to re-enable the output from test_scopes.
      	* gcc.dg/plugin/plugin.exp (plugin_test_list): Add dump-2.c.
      
      From-SVN: r264851
      David Malcolm committed
    • varasm.c (output_constant): Add new parameter merge_strings. · 5e1b4477
      2018-10-04  Bernd Edlinger  <bernd.edlinger@hotmail.de>
      
              * varasm.c (output_constant): Add new parameter merge_strings.
              Make strings properly zero terminated in merge string sections.
              (mergeable_string_section): Don't fail if the last char is non-zero.
              (assemble_variable_contents): Handle merge string sections.
              (assemble_variable): Likewise.
              (assemble_constant_contents): Likewise.
              (output_constant_def_contents): Likewise.
              (output_constructor_array_range,
              output_constructor_regular_field): Adjust call to output_constant.
              (output_object_block): Adjust call to assemble_constant_contents
              and assemble_variable_contents.
      
      testsuie:
      2018-10-04  Bernd Edlinger  <bernd.edlinger@hotmail.de>
      
              * gnat.dg/string_merge1.adb: New test.
              * gnat.dg/string_merge2.adb: New test.
              * gcc.dg/merge-all-constants-1.c: Adjust test.
              * gcc.dg/merge-all-constants-2.c: New test.
      
      From-SVN: r264850
      Bernd Edlinger committed
    • Revert "Never reload fixed form constraints memory operand" · a81a0bfa
      This reverts commit r264834.
      
      2018-10-04  Thomas Preud'homme  <thomas.preudhomme@linaro.org>
      
          Revert
          2018-10-04  Thomas Preud'homme  <thomas.preudhomme@linaro.org>
      
          gcc/
          * lra-constraints.c (process_address_1): Bail out for all
          satisfied fixed constraints.
      
      From-SVN: r264849
      Thomas Preud'homme committed
    • List myself as "libgomp (OpenACC)" and "OpenACC" maintainer · 956a7508
      	* MAINTAINERS: List myself as "libgomp (OpenACC)" and "OpenACC"
      	maintainer.
      
      From-SVN: r264848
      Thomas Schwinge committed
    • [PATCH, rs6000] Fix expected error output for test case. · f349e465
      r264355 removed some spelling suggestions including for "bool" as used
      in this test case.
      
      Bootstrapped and tested on powerpc64le-unknown-linux-gnu and
      powerpc64be-unknown-linux-gnu with no regressions.  Is this ok for trunk?
      
      2018-10-04  Bill Seurer  <seurer@linux.vnet.ibm.com>
      
      	PR target/87486
      	* gcc.target/powerpc/undef-bool-2.c: Fix expected error output.
      
      Index: gcc/testsuite/gcc.target/powerpc/undef-bool-2.c
      ===================================================================
      --- gcc/testsuite/gcc.target/powerpc/undef-bool-2.c	(revision 264812)
      +++ gcc/testsuite/gcc.target/powerpc/undef-bool-2.c	(working copy)
      @@ -9,7 +9,7 @@
       
       #include <xmmintrin.h>
       
      -bool foo (int x) /* { dg-error "unknown type name 'bool'; did you mean '_Bool'?" } */
      +bool foo (int x) /* { dg-error "unknown type name 'bool'" } */
       {
         return x == 2;
       }
      
      From-SVN: r264847
      Bill Seurer committed
    • Error about alias attribute with body definition (PR c/87483). · 96c545e5
      2018-10-04  Martin Liska  <mliska@suse.cz>
      
      	PR c/87483
      	* cgraphunit.c (process_function_and_variable_attributes):
      	Warn about a function with alias attribute and a body.
      2018-10-04  Martin Liska  <mliska@suse.cz>
      
      	PR c/87483
      	* gcc.dg/pr87483.c: New test.
      
      From-SVN: r264846
      Martin Liska committed
    • Redirect call within specific target attribute among MV clones (PR ipa/82625). · b8ce8129
      2018-10-04  Martin Liska  <mliska@suse.cz>
      
      	PR ipa/82625
      	* multiple_target.c (redirect_to_specific_clone): New function.
      	(ipa_target_clone): Use it.
      	* tree-inline.c: Fix comment.
      2018-10-04  Martin Liska  <mliska@suse.cz>
      
      	PR ipa/82625
      	* g++.dg/ext/pr82625.C: New test.
      
      From-SVN: r264845
      Martin Liska committed
    • Fix -fopt-info for plugin passes · 5d98e5a6
      Attempts to dump via -fopt-info from a plugin pass fail, due
      to the dfi->alt_state for such passes never being set.
      
      This is because the -fopt-info options were being set up per-pass
      during option-parsing (via gcc::dump_manager::opt_info_enable_passes),
      but this data was not retained or used it for passes created later
      (for plugins and target-specific passes).
      
      This patch fixes the issue by storing the -fopt-info options into
      gcc::dump_manager, refactoring the dfi-setup code out of
      opt_info_enable_passes, and reusing it for such passes, fixing the
      issue.  The patch adds a demo plugin to test that dumping from a
      plugin works.
      
      gcc/ChangeLog:
      	* dumpfile.c (gcc::dump_manager::dump_manager): Initialize new
      	fields.
      	(gcc::dump_manager::~dump_manager): Free m_optinfo_filename.
      	(gcc::dump_manager::register_pass): New member function, adapted
      	from loop body in gcc::pass_manager::register_pass, adding a
      	call to update_dfi_for_opt_info.
      	(gcc::dump_manager::opt_info_enable_passes): Store the
      	-fopt-info options into the new fields.  Move the loop
      	bodies into...
      	(gcc::dump_manager::update_dfi_for_opt_info): ...this new member
      	function.
      	* dumpfile.h (struct opt_pass): New forward decl.
      	(gcc::dump_manager::register_pass): New decl.
      	(gcc::dump_manager::update_dfi_for_opt_info): New decl.
      	(class gcc::dump_manager): Add fields "m_optgroup_flags",
      	"m_optinfo_flags", and "m_optinfo_filename".
      	* passes.c (gcc::pass_manager::register_pass): Move all of the
      	dump-handling code to gcc::dump_manager::register_pass.
      
      gcc/testsuite/ChangeLog:
      	* gcc.dg/plugin/dump-1.c: New test.
      	* gcc.dg/plugin/dump_plugin.c: New test plugin.
      	* gcc.dg/plugin/plugin.exp (plugin_test_list): Add the above.
      
      From-SVN: r264844
      David Malcolm committed
    • Add missing ChangeLog entry for previous commit · c19bc1a0
      From-SVN: r264843
      Peter Bergner committed
    • re PR rtl-optimization/87466 (IRA and LRA spill all pseudos that are live across setjmp calls) · 82957a73
      gcc/
      	PR rtl-optimization/87466
      	* target.def (setjmp_preserves_nonvolatile_regs_p): New target hook.
      	* doc/tm.texi.in (TARGET_SETJMP_PRESERVES_NONVOLATILE_REGS_P): New hook.
      	* doc/tm.texi: Regenerate.
      	* ira-lives.c (process_bb_node_lives): Use the new target hook.
      	* lra-lives.c (process_bb_lives): Likewise.
      	* config/rs6000/rs6000.c (TARGET_SETJMP_PRESERVES_NONVOLATILE_REGS_P):
      	Define.
      
      gcc/testsuite/
      	PR rtl-optimization/87466
      	* gcc.target/powerpc/pr87466.c: New test.
      
      From-SVN: r264842
      Peter Bergner committed
    • Remove superfluous assignment in add_params. · ac712e4e
      This fixes the superfluous assignment that Coverity reported in add_params,
      and changes the starting index from 0 to num_params - n in order for it to
      work properly if add_params is called multiple times.
      
      validate_params calls error so it doesn't matter that we don't check the
      results here.  The results is checked in individual parameter updates after
      front-end initialization.
      
      2018-10-04  Tamar Christina  <tamar.christina@arm.com>
      
      	* params.c (add_params): Fix initialization.
      
      From-SVN: r264841
      Tamar Christina committed
    • Fix divergence in indirect profiling (PR gcov-profile/84107). · 3edbcdbe
      2018-10-04  Martin Liska  <mliska@suse.cz>
      
      	PR gcov-profile/84107
      	* tree-profile.c (init_ic_make_global_vars):
      	Remove ic_void_ptr_var and ic_gcov_type_ptr_var.
      	Come up with new ic_tuple* variables.  Emit
      	__gcov_indirect_call{,_topn} variables.
      	(gimple_gen_ic_profiler): Access the variable
      	and emit gimple.
      	(gimple_gen_ic_func_profiler): Access
      	__gcov_indirect_call.callee field.
      	(gimple_init_gcov_profiler): Use ptr_type_node.
      	* value-prof.c (gimple_ic): Use ptr_type_node.
      2018-10-04  Martin Liska  <mliska@suse.cz>
      
      	PR gcov-profile/84107
      	* libgcov-profiler.c (__gcov_indirect_call):
      	Change type to indirect_call_tuple.
      	(struct indirect_call_tuple): New struct.
      	(__gcov_indirect_call_topn_profiler): Change type.
      	(__gcov_indirect_call_profiler_v2): Use the new
      	variables.
      	* libgcov.h (struct indirect_call_tuple): New struct
      	definition.
      
      From-SVN: r264840
      Martin Liska committed
    • [C++ PATCH] String concatenation is a thing · 668f8d45
      https://gcc.gnu.org/ml/gcc-patches/2018-10/msg00248.html
      	* lang-specs.h: Use string contatenation, not line splicing.
      
      From-SVN: r264839
      Nathan Sidwell committed
    • re PR tree-optimization/85787 (malloc_candidate_p fails to detect malloc attribute on nested phis) · 9a471714
      2018-10-04  Prathamesh Kulkarni  <prathamesh.kulkarni@linaro.org>
      
      	PR tree-optimization/85787
      	* ipa-pure-const.c (malloc_candidate_p_1): Move most of malloc_candidate_p
      	into this function and add support for detecting multiple phis.
      	(DUMP_AND_RETURN): Move from malloc_candidate_p into top-level macro.
      
      testsuite/
      	* gcc.dg/ipa/propmalloc-4.c: New test.
      
      From-SVN: r264838
      Prathamesh Kulkarni committed
    • contrib: Add unused_functions.py script · 75fcc3eb
      For a set of object-files, determine symbols that are
       - public but should be static
      
      2018-10-04  Bernhard Reutner-Fischer  <aldot@gcc.gnu.org>
      
      	* unused_functions.py: New file.
      
      From-SVN: r264837
      Bernhard Reutner-Fischer committed
    • cunroll-15.c: Add XFAILs for arm and powerpc. · 289380f1
      2018-10-04  Richard Biener  <rguenther@suse.de>
      
      	* gcc.dg/tree-ssa/cunroll-15.c: Add XFAILs for arm and powerpc.
      
      From-SVN: r264836
      Richard Biener committed
    • Call ultimate_alias_target for node being inlined (PR ipa/87491). · 5e626cd9
      2018-10-04  Martin Liska  <mliska@suse.cz>
      
      	PR ipa/87491
      	* ipa-inline.c (inline_to_all_callers_1):
      	Call ultimate_alias_target for node being inlined.
      
      From-SVN: r264835
      Martin Liska committed
    • Never reload fixed form constraints memory operand · b4ee6509
      The unconditional reload of address operand for recognized instruction
      in process_address_1 prevent the patch fixing PR85434 from working as
      expected. The code in that patch attempts to control which registers are
      used to make PIC access but the reload performed by process_address_1
      will use generic PIC access. This patch removes the test for the
      instruction to be unrecognized to do the reload, thus always avoiding to
      reload address operand for fixed constraints (such as "X" used in the
      patch).
      
      2018-10-04  Thomas Preud'homme  <thomas.preudhomme@linaro.org>
      
          gcc/
          * lra-constraints.c (process_address_1): Bail out for all
          satisfied fixed constraints.
      
      From-SVN: r264834
      Thomas Preud'homme committed
    • gimple-ssa-sprintf.c (format_string): Do not hardcode size of target's wchar_t. · 0863decd
              * gimple-ssa-sprintf.c (format_string): Do not hardcode size of
              target's wchar_t.
              * tree.c (get_typenode_from_name): Moved from fortran/trans-types.c.
              * tree.h (get_typenode_from_name): Prototype.
      
              * trans-types.c (get_typenode_from_name): Moved into gcc/tree.c.
      
      From-SVN: r264833
      Jeff Law committed
    • Daily bump. · 74ac6074
      From-SVN: r264831
      GCC Administrator committed
  2. 03 Oct, 2018 17 commits
    • i386.md (*cmp<X87MODEF:mode>_<SWI24:mode>_i387): Change operand 2 predicate to… · c7d53a7c
      i386.md (*cmp<X87MODEF:mode>_<SWI24:mode>_i387): Change operand 2 predicate to nonimmediate_operand.
      
      	* config/i386/i386.md (*cmp<X87MODEF:mode>_<SWI24:mode>_i387):
      	Change operand 2 predicate to nonimmediate_operand.
      	(*cmp<X87MODEF:mode>_<SWI24:mode>_cc_i387): Ditto.
      
      From-SVN: r264827
      Uros Bizjak committed
    • libgcc2.c (isnan): Use __builtin_isnan. · af8096fc
      	* libgcc2.c (isnan): Use __builtin_isnan.
      	(isfinite): Use __builtin_isfinite.
      	(isinf): Use __builtin_isinf.
      
      From-SVN: r264823
      Uros Bizjak committed
    • gimple-ssa-sprintf.c (struct fmtresult): Add new member and initialize it. · a41cc59d
      	* gimple-ssa-sprintf.c (struct fmtresult): Add new member and
      	initialize it.
      	(get_string_length): Detect unterminated arrays.
      	(format_string): Same.
      	(format_directive): Warn about unterminated arrays.
      	(handle_gimple_call): Mark statements with no_warning as needed.
      
      	* gcc.dg/warn-sprintf-no-nul.c: New test.
      
      Co-Authored-By: Jeff Law <law@redhat.com>
      
      From-SVN: r264822
      Martin Sebor committed
    • RISC-V: Add macro for ilp32e ABI. Cleanup white space. · 119b4963
      	gcc/
      	* config/riscv/riscv-c.c (riscv_cpu_cpp_builtins): For ABI_ILP32E,
      	also define __riscv_abi_rve.  Delete trailing white space.
      
      From-SVN: r264821
      Jim Wilson committed
    • Enable LRA register allocator for PDP11. · 5079ff15
          Enable LRA register allocator for PDP11. -- missed checking in
          ChangeLog.
      
      From-SVN: r264820
      Paul Koning committed
    • Enable LRA register allocator for PDP11. · 0a7eb8df
          * config/pdp11/constraints.md (Q): Use define_memory_constraints.
          (R): Likewise.
          (D): Likewise.
          * config/pdp11/pdp11.c (pdp11_lra_p): New function.
          * config/pdp11/pdp11.opt (-mlra): New option.
          * doc/invoke.texi (PDP-11 Options): Document -mlra.
      
      From-SVN: r264819
      Paul Koning committed
    • i386.md (*<absneg:code>extendsfdf2): Remove. · f707a037
      	* config/i386/i386.md (*<absneg:code>extendsfdf2): Remove.
      	(*<absneg:code>extend<mode>xf2): Ditto.
      
      From-SVN: r264818
      Uros Bizjak committed
    • re PR tree-optimization/87415 (wrong code at -O1 and above on x86_64-linux-gnu) · 9b918e82
      	PR tree-optimization/87415
      	* tree-vrp.c (set_value_range_with_overflow): Special case one bit
      	precision fields.
      
      From-SVN: r264817
      Aldy Hernandez committed
    • gimple-fold.c (get_range_strlen): Only set *nonstr when an unterminated string is discovered. · 78125561
      	* gimple-fold.c (get_range_strlen): Only set *nonstr when
      	an unterminated string is discovered.  Bubble up range
      	even for unterminated strings.
      	(gimple_fold_builtin_strlen): Do not fold if get_range_strlen
      	indicates the string was not terminated via NONSTR.
      
      From-SVN: r264816
      Jeff Law committed
    • tree-vrp.c (extract_range_from_unary_expr): Special case all pointer conversions. · 2e103ae2
      	* tree-vrp.c (extract_range_from_unary_expr): Special case all
      	pointer conversions.
      	Do not do anything special for anti-ranges.
      
      From-SVN: r264815
      Aldy Hernandez committed
    • Implement P0840, language support for empty objects. · bedf03a2
      	The [[no_unique_address]] attribute on a non-static data member
      	enables the equivalent of the empty base optimization.
      
      gcc/cp/
      	* tree.c (handle_no_unique_addr_attribute): New.
      	(cxx_attribute_table): Add [[no_unique_address]].
      	* class.c (field_poverlapping_p): New.
      	(layout_class_type): Check it.  Adjust DECL_SIZE of potentially
      	overlapping fields.
      	(layout_empty_base_or_field): Rename from layout_empty_base, handle
      	FIELD_DECL as well.
      	(build_base_field, record_subobject_offsets): Adjust.
      c-family/
      	* c-lex.c (c_common_has_attribute): Add no_unique_address.
      
      From-SVN: r264813
      Jason Merrill committed
    • PR libstdc++/59439 optimize uses of classic ("C") std::locale · 749c0e1d
      The global locale::_Impl that represents the "C" locale is never
      destroyed, so there is no need to keep track of reference count updates
      for that object. This greatly reduce contention between threads that
      refer to the classic locale. Since the global std::locale initially uses
      the classic locale, this benefits the common case for any code using the
      global locale, such as construction/destruction of iostream objects.
      
      All these updates are done inside libstdc++.so so there's no need to
      worry about users' objects having inlined old versions of the code which
      still update the reference count for the classic locale.
      
      	PR libstdc++/59439
      	* src/c++98/locale.cc (locale::locale(const locale&)): Bypass
      	reference count updates for the classic locale.
      	(locale::~locale()): Likewise.
      	(locale::operator=(const locale&)): Likewise.
      	* src/c++98/locale_init.cc (locale::locale()): Likewise.
      	(locale::global(const locale&)): Likewise.
      
      From-SVN: r264811
      Jonathan Wakely committed
    • Fix ARM_TARGET2_DWARF_FORMAT for vxworks · e7df9e44
      2018-10-03  Jérôme Lambourg  <lambourg@adacore.com>
      
      	* config/arm/vxworks.h (ARM_TARGET2_DWARF_FORMAT): Adjust to
      	DW_EH_PE_pcrel | DW_EH_PE_indirect for RTPs.
      
      From-SVN: r264808
      Jerome Lambourg committed
    • Properly mark lambdas in GCOV (PR gcov-profile/86109). · f2db4602
      2018-10-03  Martin Liska  <mliska@suse.cz>
      
      	PR gcov-profile/86109
      	* coverage.c (coverage_begin_function): Do not
      	mark lambdas as artificial.
      	* tree-core.h (struct GTY): Remove tm_clone_flag
      	and introduce new lambda_function.
      	* tree.h (DECL_LAMBDA_FUNCTION): New macro.
      2018-10-03  Martin Liska  <mliska@suse.cz>
      
      	PR gcov-profile/86109
      	* parser.c (cp_parser_lambda_declarator_opt):
      	Set DECL_LAMBDA_FUNCTION for lambdas.
      2018-10-03  Martin Liska  <mliska@suse.cz>
      
      	PR gcov-profile/86109
      	* g++.dg/gcov/pr86109.C: New test.
      
      From-SVN: r264806
      Martin Liska committed
    • 2018-10-03 François Dumont <fdumont@gcc.gnu.org> · 784779d4
      	* include/debug/map.h
      	(map<>::emplace<>(_Args&&...)): Use C++11 direct initialization.
      	(map<>::emplace_hint<>(const_iterator, _Args&&...)): Likewise.
      	(map<>::insert(value_type&&)): Likewise.
      	(map<>::insert<>(_Pair&&)): Likewise.
      	(map<>::insert<>(const_iterator, _Pair&&)): Likewise.
      	(map<>::try_emplace): Likewise.
      	(map<>::insert_or_assign): Likewise.
      	(map<>::insert(node_type&&)): Likewise.
      	(map<>::insert(const_iterator, node_type&&)): Likewise.
      	(map<>::erase(const_iterator)): Likewise.
      	(map<>::erase(const_iterator, const_iterator)): Likewise.
      	* include/debug/multimap.h
      	(multimap<>::emplace<>(_Args&&...)): Use C++11 direct initialization.
      	(multimap<>::emplace_hint<>(const_iterator, _Args&&...)): Likewise.
      	(multimap<>::insert<>(_Pair&&)): Likewise.
      	(multimap<>::insert<>(const_iterator, _Pair&&)): Likewise.
      	(multimap<>::insert(node_type&&)): Likewise.
      	(multimap<>::insert(const_iterator, node_type&&)): Likewise.
      	(multimap<>::erase(const_iterator)): Likewise.
      	(multimap<>::erase(const_iterator, const_iterator)): Likewise.
      	* include/debug/set.h
      	(set<>::emplace<>(_Args&&...)): Use C++11 direct initialization.
      	(set<>::emplace_hint<>(const_iterator, _Args&&...)): Likewise.
      	(set<>::insert(value_type&&)): Likewise.
      	(set<>::insert<>(const_iterator, value_type&&)): Likewise.
      	(set<>::insert(const_iterator, node_type&&)): Likewise.
      	(set<>::erase(const_iterator)): Likewise.
      	(set<>::erase(const_iterator, const_iterator)): Likewise.
      	* include/debug/multiset.h
      	(multiset<>::emplace<>(_Args&&...)): Use C++11 direct initialization.
      	(multiset<>::emplace_hint<>(const_iterator, _Args&&...)): Likewise.
      	(multiset<>::insert<>(value_type&&)): Likewise.
      	(multiset<>::insert<>(const_iterator, value_type&&)): Likewise.
      	(multiset<>::insert(node_type&&)): Likewise.
      	(multiset<>::insert(const_iterator, node_type&&)): Likewise.
      	(multiset<>::erase(const_iterator)): Likewise.
      	(multiset<>::erase(const_iterator, const_iterator)): Likewise.
      
      From-SVN: r264805
      François Dumont committed
    • Daily bump. · da76e70f
      From-SVN: r264804
      GCC Administrator committed
  3. 02 Oct, 2018 2 commits