1. 18 Oct, 2018 3 commits
    • Simplify subreg of vec_merge of vec_duplicate · 294973a4
      We can simplify
      
        (subreg (vec_merge (vec_duplicate X)
      		     (vector)
      		     (const_int ((1 << N) | M)))
      	  (N * sizeof (X)))
      
      to X when mode of X is the same as of mode of subreg.
      
      gcc/
      
      	PR target/87537
      	* simplify-rtx.c (simplify_subreg): Simplify subreg of vec_merge
      	of vec_duplicate.
      	(test_vector_ops_duplicate): Add test for a scalar subreg of a
      	VEC_MERGE of a VEC_DUPLICATE.
      
      gcc/testsuite/
      
      	PR target/87537
      	* gcc.target/i386/pr87537-1.c: New test.
      
      From-SVN: r265260
      H.J. Lu committed
    • revert: [multiple changes] · 7702ab65
      2018-10-18  François Dumont  <fdumont@gcc.gnu.org>
      
      	Partial revert.
      	2018-10-08  François Dumont  <fdumont@gcc.gnu.org>
      
      	* include/debug/list (list<>::cbegin()): Use C++11 direct
      	initialization.
      	(list<>::cend()): Likewise.
      	(list<>::erase(const_iterator, const_iterator)): Ensure consistent
      	iterator comparisons.
      	(list<>::splice(const_iterator, list&&, const_iterator,
      	const_iterator)): Likewise.
      
      	Partial revert.
      	2018-10-15  François Dumont  <fdumont@gcc.gnu.org>
      
      	* include/debug/vector (vector<>::cbegin()): Use C++11 direct
      	initialization.
      	(vector<>::cend()): Likewise.
      	(vector<>::insert(const_iterator, const _Tp&)): Use consistent
      	iterator comparison.
      	(vector<>::erase(const_iterator)): Likewise.
      	(vector<>::erase(const_iterator, const_iterator)): Likewise.
      
      From-SVN: r265259
      François Dumont committed
    • Daily bump. · 7bed4de2
      From-SVN: r265255
      GCC Administrator committed
  2. 17 Oct, 2018 16 commits
    • Add -std=c2x, -std=gnu2x, -Wc11-c2x-compat, C2X _Static_assert support. · 9f936c86
      Now new features are starting to be added to a C2X draft (in the C2x
      branch of the C standard git repository, no public WG14 document yet),
      it's time to add -std=c2x and associated options to GCC for use in
      enabling C2X features.
      
      This patch adds the expected set of options: -std=c2x, -std=gnu2x,
      -Wc11-c2x-compat.  A first C2X feature is added (the only one so far
      in the repository that's obviously relevant to GCC): support (as in
      C++) for the string constant to be omitted in _Static_assert.  This
      feature is duly also supported as an extension in earlier standard
      modes (diagnosed with -pedantic, unless -Wno-c11-c2x-compat is given,
      or with -Wc11-c2x-compat even in C2X mode).
      
      Bootstrapped with no regressions on x86_64-pc-linux-gnu.
      
      gcc/
      	* doc/cpp.texi (__STDC_VERSION__): Document C2X handling.
      	* doc/invoke.texi (-std=c2x, -std=gnu2x): Document new options.
      	* doc/standards.texi (C Language): Document C2X.
      	* dwarf2out.c (highest_c_language), config/rl78/rl78.c
      	(rl78_option_override): Handle "GNU C2X" language name.
      
      gcc/c/
      	* c-errors.c (pedwarn_c11): New function.
      	* c-parser.c (disable_extension_diagnostics): Save
      	warn_c11_c2x_compat and set it to 0.
      	(restore_extension_diagnostics): Restore warn_c11_c2x_compat.
      	(c_parser_static_assert_declaration_no_semi): Handle
      	_Static_assert without string constant.
      	* c-tree.h (pedwarn_c11): New prototype.
      
      gcc/c-family/
      	* c-common.c (flag_isoc2x): New variable.
      	* c-common.h (clk_c): Update comment to reference C2X.
      	(flag_isoc99, flag_isoc11): Update comments to reference future
      	standard versions in general.
      	(flag_isoc2x): Declare.
      	* c-opts.c (set_std_c2x): New function.
      	(c_common_handle_option): Handle -std=c2x and -std=gnu2x.
      	(set_std_c89, set_std_c99, set_std_c11, set_std_c17): Set
      	flag_isoc2x to 0.
      	* c.opt (Wc11-c2x-compat, std=c2x, std=gnu2x): New options.
      
      gcc/testsuite/
      	* gcc.dg/c11-static-assert-7.c, gcc.dg/c11-static-assert-8.c,
      	gcc.dg/c11-static-assert-9.c, gcc.dg/c2x-static-assert-1.c,
      	gcc.dg/c2x-static-assert-2.c, gcc.dg/c99-static-assert-2.c,
      	gcc.dg/gnu2x-static-assert-1.c: New tests.
      	* gcc.dg/missing-symbol-3.c: Update expected fix-it text.
      
      libcpp/
      	* include/cpplib.h (enum c_lang): Add CLK_GNUC2X and CLK_STDC2X.
      	* init.c (lang_defaults): Add GNUC2X and STDC2X entries.
      	(cpp_init_builtins): Define __STDC_VERSION__ to 202000L for C2X.
      
      From-SVN: r265251
      Joseph Myers committed
    • Update C17 option descriptions not to say "expected to be published". · 7a8a92c4
      	* c.opt (std=c17, std=c18, std=gnu17, std=gnu18, std=iso9899:2017)
      	(std=iso9899:2018): Document C17 as published in 2018.
      
      From-SVN: r265250
      Joseph Myers committed
    • Update manual references for C17 having been published. · 7dc41f3d
      This patch makes references in the manual to C17 reflect it having
      been published in July 2018.  (For the reasons it took so long to get
      to ballot and publication, see the WG14 convenor's report to the last
      SC22 plenary - SC22 N5297 - where it references "A troubling new trend
      where ISO CS has begun enforcing undocumented rules that are approved
      neither by the TMB nor by the WG 14 editors, leading to a decrease in
      the usefulness of standards documents.".)
      
      Tested with "make info html pdf".
      
      	* doc/invoke.texi (-std=c17), doc/standards.texi (C Language):
      	Document C17 as published in 2018.
      
      From-SVN: r265249
      Joseph Myers committed
    • Fix select-type regression · 91f9b2e0
              PR fortran/87632
              * resolve.c (resolve_select_type): Use correct variable.
      
              PR fortran/87632
              * gfortran.dg/select_type_47.f90: New.
      
      From-SVN: r265248
      Tobias Burnus committed
    • re PR libstdc++/87619 (sizeof(std::variant) can be reduced if its variant_size is UCHAR_MAX) · 4026227f
      PR libstdc++/87619
      
      * include/std/variant (__select_index): Fix an off-by-one.
      * testsuite/20_util/variant/87619.cc: New.
      
      From-SVN: r265247
      Ville Voutilainen committed
    • libgcc: apply LIB2FUNCS_EXCLUDE logic to LIB2FUNCS_ST · fc8abc46
      One target file (config/c6x/t-elf) lists _printf and _gcc_bcmp in
      LIB2FUNCS_EXCLUDE, but that does not have any effect, since those are
      not filtered away from LIB2FUNCS_ST. Another option is to do as in
      config/rl78/t-rl78, which explicitly sets LIB2FUNCS_ST
      
      # Remove __gcc_bcmp from LIB2FUNCS_ST
      LIB2FUNCS_ST = _eprintf
      
      but honouring LIB2FUNCS_EXCLUDE also for LIB2FUNCS_ST seems more
      natural.
      
      From-SVN: r265246
      Rasmus Villemoes committed
    • re PR middle-end/87623 (bytes swapped in register when comparing cause fail when… · 1906e1a6
      re PR middle-end/87623 (bytes swapped in register when comparing cause fail when compiled with  -O1 or higher)
      
      	PR middle-end/87623
      	* fold-const.c (fold_truth_andor_1): If the right side is not constant,
      	bail out if both sides do not have the same storage order.
      
      From-SVN: r265242
      Eric Botcazou committed
    • bitmap.c (bitmap_head::dump): New. · 54994253
      	* bitmap.c (bitmap_head::dump): New.
      	* bitmap.h (bitmap_head): Add dump().
      	* gimple-ssa-evrp-analyze.c
      	(evrp_range_analyzer::try_find_new_range): Adjust for value_range API.
      	(evrp_range_analyzer::set_ssa_range_info): Same.
      	(evrp_range_analyzer::record_ranges_from_phis): Same.
      	(evrp_range_analyzer::record_ranges_from_stmt): Same.
      	* gimple-ssa-evrp.c (evrp_dom_walker::before_dom_children): Same.
      	* gimple-ssa-sprintf.c (get_int_range): Same.
      	(format_integer): Same.
      	(sprintf_dom_walker::handle_gimple_call): Same.
      	* ipa-cp.c (ipcp_vr_lattice::meet_with_1): Same.
      	(ipcp_vr_lattice::top_p): Same.
      	(ipcp_vr_lattice::bottom_p): Same.
      	(ipcp_vr_lattice::set_to_bottom): Same.
      	(ipa_vr_operation_and_type_effects): Same.
      	(propagate_vr_across_jump_function): Same.
      	(ipcp_store_vr_results): Same.
      	* ipa-prop.c (struct ipa_vr_ggc_hash_traits): Same.
      	(ipa_print_node_jump_functions_for_edge): Same.
      	(ipa_get_value_range): Same.
      	(ipa_compute_jump_functions_for_edge): Same.
      	(ipa_write_jump_function): Same.
      	* tree-ssa-dom.c (simplify_stmt_for_jump_threading): Same.
      	* tree-ssa-threadedge.c (record_temporary_equivalences_from_phis):
      	Same.
      	* vr-values.c (set_value_range_to_nonnegative): Same.
      	(set_value_range_to_truthvalue): Same.
      	(vr_values::get_value_range): Same.
      	(vr_values::set_defs_to_varying): Same.
      	(vr_values::update_value_range): Same.
      	(symbolic_range_based_on_p): Same.
      	(vr_values::op_with_boolean_value_range_p): Same.
      	(vr_values::extract_range_for_var_from_comparison_expr): Same.
      	(vr_values::extract_range_from_ssa_name): Same.
      	(vr_values::extract_range_from_binary_expr): Same.
      	(vr_values::extract_range_from_unary_expr): Same.
      	(vr_values::extract_range_from_cond_expr): Same.
      	(vr_values::extract_range_from_comparison): Same.
      	(vr_values::check_for_binary_op_overflow): Same.
      	(vr_values::extract_range_basic): Same.
      	(vr_values::extract_range_from_assignment): Same.
      	(compare_ranges): Same.
      	(compare_range_with_value): Same.
      	(vr_values::adjust_range_with_scev): Same.
      	(vrp_valueize): Same.
      	(vrp_valueize_1): Same.
      	(vr_values::get_vr_for_comparison): Same.
      	(vr_values::compare_name_with_value): Same.
      	(vr_values::compare_names): Same.
      	(vr_values::vrp_evaluate_conditional): Same.
      	(find_case_label_ranges): Same.
      	(vr_values::vrp_visit_switch_stmt): Same.
      	(vr_values::extract_range_from_phi_node): Same.
      	(vr_values::simplify_div_or_mod_using_ranges): Same.
      	(vr_values::simplify_bit_ops_using_ranges): Same.
      	(test_for_singularity): Same.
      	(range_fits_type_p): Same.
      	(vr_values::simplify_cond_using_ranges_1): Same.
      	(vr_values::simplify_switch_using_ranges): Same.
      	(vr_values::simplify_float_conversion_using_ranges): Same.
      	(vr_values::two_valued_val_range_p): Same.
      	(vr_values::add_equivalence): Move to value_range::equiv_add.
      	* vr-values.h (vr_values::add_equivalence): Remove.
      	(VR_INITIALIZER): Remove.
      	* tree-vrp.c (value_range::set): New.
      	(value_range::equiv_add): New.
      	(value_range::value_range): New.
      	(value_range::deep_copy): New.
      	(value_range::check): New.
      	(value_range::equal_p): New.
      	(value_range::ignore_equivs_equal_p): New.
      	(value_range::operator==): New.
      	(value_range::operator!=): New.
      	(value_range::symbolic_p): New.
      	(value_range::numeric_p): New.
      	(value_range::set_undefined): New.
      	(value_range::set_varying): New.
      	(value_range::may_contain_p): New.
      	(value_range::equiv_clear): New.
      	(value_range::singleton_p): New.
      	(value_range::intersect): New.
      	(value_range::dump): New.
      	(value_range::set_and_canonicalize): New.
      	(set_value_range): Adjust for value_range API.
      	(set_value_range_to_undefined): Same.
      	(set_value_range_to_varying): Same.
      	(set_and_canonicalize_value_range): Same.
      	(set_value_range_to_nonnull): Same.
      	(set_value_range_to_null): Same.
      	(range_is_null): Same.
      	(range_is_nonnull): Same.
      	(range_int_cst_p): Same.
      	(range_int_cst_singleton_p): Same.
      	(symbolic_range_p): Same.
      	(range_includes_zero_p): Same.
      	(value_range_constant_singleton): Same.
      	(vrp_set_zero_nonzero_bits): Same.
      	(ranges_from_anti_range): Same.
      	(extract_range_into_wide_ints): Same.
      	(extract_range_from_multiplicative_op): Same.
      	(set_value_range_with_overflow): Same.
      	(extract_range_from_binary_expr_1): Same.
      	(extract_range_from_unary_expr): Same.
      	(dump_value_range): Same.
      	(debug_value_range): Same.
      	(vrp_prop::check_array_ref): Same.
      	(vrp_prop::check_mem_ref): Same.
      	(vrp_prop::vrp_initialize): Same.
      	(vrp_prop::visit_stmt): Same.
      	(intersect_ranges): Same.
      	(vrp_prop::visit_phi): Same.
      	(vrp_prop::vrp_finalize): Same.
      	(determine_value_range_1): Same.
      	(determine_value_range): Same.
      	(vrp_intersect_ranges_1): Rename to...
      	(vrp_intersect_1): this.
      	(vrp_intersect_ranges): Rename to...
      	(value_range::intersect_helper): ...this.
      	(vrp_meet_1): Rename to...
      	(value_range::union_helper): ...this.
      	(vrp_meet): Rename to...
      	(value_range::union_): ...this.
      	(copy_value_range): Remove.
      	* tree-vrp.h (struct value_range): Rewrite into a proper class.
      	(value_range::vrtype): New.
      	(value_range::type): New.
      	(value_range::equiv): New.
      	(value_range::min): New.
      	(value_range::max): New.
      	(value_range::varying_p): New.
      	(value_range::undefined_p): New.
      	(value_range::null_p): New.
      	(value_range::equiv_add): New.
      	(copy_value_range): Remove.
      
      From-SVN: r265241
      Aldy Hernandez committed
    • Run selftests for C++ as well as C · 033eb567
      gcc/ChangeLog:
      	* Makefile.in (SELFTEST_TARGETS): New.
      	(selftest) Change from s-selftest-c to $(SELFTEST_TARGETS).
      	(C_SELFTEST_FLAGS, C_SELFTEST_DEPS, s-selftest-c, selftest-c-gdb)
      	(selftest-gdb, selftest-c-valgrind, selftest-valgrind): Move to
      	c/Make-lang.in.
      	(CPP_SELFTEST_FLAGS, CPP_SELFTEST_DEPS, s-selftest-c++)
      	(selftest-c++-gdb, selftest-c++-valgrind): Move to
      	cp/Make-lang.in.
      	* configure: Regenerate.
      	* configure.ac (selftest_languages): New.
      
      gcc/brig/ChangeLog:
      	* Make-lang.in (selftest-brig): New.
      
      gcc/c/ChangeLog:
      	* Make-lang.in (selftest-c): New.
      	(C_SELFTEST_FLAGS, C_SELFTEST_DEPS, s-selftest-c, selftest-c-gdb)
      	(selftest-gdb, selftest-c-valgrind, selftest-valgrind): Move here
      	from gcc/Makefile.in.
      
      gcc/cp/ChangeLog:
      	* Make-lang.in (selftest-c++): New.
      	(CPP_SELFTEST_FLAGS, CPP_SELFTEST_DEPS, s-selftest-c++)
      	(selftest-c++-gdb, selftest-c++-valgrind): Move here from
      	gcc/Makefile.in.
      
      gcc/fortran/ChangeLog:
      	* Make-lang.in (selftest-fortran): New.
      
      gcc/go/ChangeLog:
      	* Make-lang.in (selftest-go): New.
      
      gcc/jit/ChangeLog:
      	* Make-lang.in (selftest-jit): New.
      
      gcc/lto/ChangeLog:
      	* Make-lang.in (selftest-lto): New.
      
      gcc/objc/ChangeLog:
      	* Make-lang.in (selftest-objc): New.
      
      gcc/objcp/ChangeLog:
      	* Make-lang.in (selftest-obj-c++): New.
      
      From-SVN: r265240
      David Malcolm committed
    • tree-vrp.c (extract_range_from_multiplicative_op): Remove overflow wraps argument. · e8f1d5cb
              * tree-vrp.c (extract_range_from_multiplicative_op): Remove
      	overflow wraps argument.
              (extract_range_from_binary_expr_1): Do not pass overflow wraps to
      	wide_int_range_multiplicative_op.
              * wide-int-range.cc (wide_int_range_mult_wrapping): Remove
      	overflow wraps argument.
              (wide_int_range_multiplicative_op): Same.
              (wide_int_range_lshift): Same.
              (wide_int_range_div): Same.
              * wide-int-range.h (wide_int_range_multiplicative_op): Same.
              (wide_int_range_lshift): Same.
              (wide_int_range_div): Same.
      
      From-SVN: r265238
      Aldy Hernandez committed
    • wide-int-range.h (wide_int_range_shift_undefined_p): Adjust to use sign as argument. · fa6b20f3
      	* wide-int-range.h (wide_int_range_shift_undefined_p): Adjust to
      	use sign as argument.
      	* tree-vrp.c (extract_range_from_binary_expr_1): Pass sign to
      	wide_int_range_shift_undefined_p.
      
      From-SVN: r265237
      Aldy Hernandez committed
    • 2018-10-17 Paolo Carlini <paolo.carlini@oracle.com> · cd1e244a
      	* Fix typo in ChangeLog.
      
      From-SVN: r265234
      Paolo Carlini committed
    • re PR c++/84705 (internal compiler error: in add_stmt, at cp/semantics.c:390) · 2be99998
      /cp
      2018-10-17  Paolo Carlini  <paolo.carlini@oracle.com>
      
      	PR c++/84705
      	* init.c (build_cplus_new): Avoid duplicate diagnostic about
      	incomplete type, early return error_mark_node if the second
      	argument is error_mark_node.
      
      /testsuite
      2018-10-17  Paolo Carlini  <paolo.carlini@oracle.com>
      
      	PR c++/84705
      	* g++.dg/cpp0x/pr84705.C: New.
      
      From-SVN: r265233
      Paolo Carlini committed
    • re PR fortran/56386 ([F03] ICE with ASSOCIATE construct and an derived type array component) · ece66526
      2018-10-17  Paul Thomas  <pault@gcc.gnu.org>
      
      	PR fortran/56386
      	PR fortran/58906
      	PR fortran/77385
      	PR fortran/80260
      	PR fortran/82077
      	* resolve.c (resolve_variable): Fix up expressions with array
      	associate names, where the parser did not detect that this is
      	array and there was no array part_ref in the expression.
      
      2018-10-17  Paul Thomas  <pault@gcc.gnu.org>
      
      	PR fortran/56386
      	PR fortran/58906
      	PR fortran/77385
      	* gfortran.dg/associate_44.f90 : New test.
      
      	PR fortran/80260
      	* gfortran.dg/select_type_45.f90 : New test.
      
      	PR fortran/82077
      	* gfortran.dg/select_type_46.f90 : New test.
      
      From-SVN: r265232
      Paul Thomas committed
    • Daily bump. · 17d6b74d
      From-SVN: r265228
      GCC Administrator committed
    • * es.po: Update. · 9419a8e2
      From-SVN: r265223
      Joseph Myers committed
  3. 16 Oct, 2018 17 commits
    • Fix regression in std::random_device default constructor · ec2e0ad5
      When the default constructor was split out into a separate function (in
      r261522) I accidentally  made it call _M_init("mt19937") instead of
      _M_init_pretr1("mt19937"). That means it will always throw an exception,
      because "mt19937" isn't a valid token accepted by the _M_init function.
      Restore the original behaviour by calling _M_init_pretr1("mt19937").
      
      	* include/bits/random.h (random_device) [!_GLIBCXX_USE_DEV_RANDOM]:
      	Fix default constructor to call correct function.
      
      From-SVN: r265218
      Jonathan Wakely committed
    • Extend source-expr test case · 01982cfb
              PR fortran/67125
              * gfortran.dg/allocate_with_source_26.f90: Extend
              testcase with polymorphic variables.
      
      From-SVN: r265215
      Tobias Burnus committed
    • Fix bounds with ALLOCATE with source-expr · c1525930
              PR fortran/67125
              * trans-array.c (gfc_array_init_size, gfc_array_allocate):
              Rename argument e3_is_array_constr to e3_has_nodescriptor
              and update comments.
              * trans-stmt.c (gfc_trans_allocate): Also fix lower bound
              to 1 for nonalloc/nonpointer func results/vars besides
              array constructors.
      
              PR fortran/67125
              * gfortran.dg/allocate_with_source_26.f90: New.
      
      From-SVN: r265212
      Tobias Burnus committed
    • Handle form_team w/ function args · 91ab2a1d
              PR fortran/87556
              * trans-stmt.c (form_team, change_team, sync_team):
              Don't ignore argse.pre/argse.post.
      
      From-SVN: r265211
      Tobias Burnus committed
    • [AArch64] Use @ pattern to eliminate switch statement in one more place · 21cebf90
      We can use the new '@' modifier to MD patterns to generate mode-parametrised gen_ functions
      for the despeculate_copy patterns and therefore remove the switch on modes in aarch64.c
      that is used to pick the right generator. This simplifies the code. 
      
      	* config/aarch64/aarch64.md (despeculate_copy<ALLI_TI:mode>):
      	Rename to...
      	(@despeculate_copy<ALLI_TI:mode>): ... This.
      	* config/aarch64/aarch64.c (aarch64_speculation_safe_value): Remove
      	switch statement.
      
      From-SVN: r265210
      Kyrylo Tkachov committed
    • Rename namespace alias in test to avoid name collision · 436ea0e5
      	* testsuite/experimental/net/internet/address/v4/creation.cc: Do not
      	declare ip in global namespace, to avoid collision with struct ip
      	defined in <netinet/ip.h>.
      
      From-SVN: r265205
      Jonathan Wakely committed
    • Fix versioned namespace macros for Networking TS · a70a4be9
      We no longer put the versioned namespace macros on the innermost
      namespace, but always nested directly below namespace std.
      
      	* include/experimental/bits/net.h: Move versioned namespace macros
      	to correct location.
      	* include/experimental/buffer: Likewise.
      	* include/experimental/executor: Likewise.
      	* include/experimental/internet: Likewise.
      	* include/experimental/io_context: Likewise.
      	* include/experimental/netfwd: Likewise.
      	* include/experimental/socket: Likewise.
      	* include/experimental/timer: Likewise.
      
      From-SVN: r265204
      Jonathan Wakely committed
    • Use autoconf to check for features needed by Networking TS · 82a0f2fd
      	* config.h.in: Regenerate.
      	* configure: Regenerate.
      	* configure.ac: Check for headers used by Networking TS.
      	* include/experimental/executor: Include <condition_variable>
      	instead of <mutex>.
      	* include/experimental/internet: Use autoconf macros for available
      	headers.  Include <sys/socket.h> for.  Remove <cstring> and use
      	__builtin_memcpy and __builtin_strchr.
      	(resolver_errc) [!_GLIBCXX_HAVE_NETDB_H]: Do not define.
      	(address_v4::to_string, address_v6::to_string)
      	[!_GLIBCXX_HAVE_ARPA_INET_H]: Likewise.
      	(basic_resolver_results) [!_GLIBCXX_HAVE_NETDB_H]: Make private
      	constructors report errors.
      	[!_GLIBCXX_HAVE_NETINET_TCP_H] (tcp::no_delay): Do not define.
      	* include/experimental/io_context: Likewise.
      	* include/experimental/socket: Likewise.
      	[!_GLIBCXX_HAVE_SYS_SOCKET_H, !_GLIBCXX_HAVE_POLL_H] (socket_base): Do
      	not define nested types when relevant header not available.
      	(__socket_impl::native_non_blocking) [!_GLIBCXX_HAVE_FCNTL_H]: Report
      	an error.
      	(__basic_socket_impl::open, __basic_socket_impl::local_endpoint)
      	(__basic_socket_impl::bind) [!_GLIBCXX_HAVE_SYS_SOCKET_H]: Likewise.
      	(__basic_socket_impl::io_control) [!_GLIBCXX_HAVE_SYS_IOCTL_H]:
      	Likewise.
      	(basic_socket::at_mark, basic_socket::shutdown)
      	(basic_socket::remote_endpoint, basic_socket::connect)
      	(basic_socket::async_connect) [!_GLIBCXX_HAVE_SYS_SOCKET_H]: Likewise.
      	(basic_socket::available) [_GLIBCXX_HAVE_SYS_IOCTL_H]: Check macro
      	for <sys/ioctl.h> availability.
      	(basic_socket::wait) [!_GLIBCXX_HAVE_POLL_H]: Likewise.
      	(basic_datagram_socket::receive, basic_datagram_socket::async_receive)
      	(basic_datagram_socket::receive_from)
      	(basic_datagram_socket::async_receive_from)
      	(basic_datagram_socket::send, basic_datagram_socket::async_send)
      	(basic_datagram_socket::send_to, basic_datagram_socket::async_send_to)
      	[!_GLIBCXX_HAVE_SYS_SOCKET_H]: Likewise.
      	(basic_stream_socket::receive, basic_stream_socket::async_receive)
      	(basic_stream_socket::send, basic_stream_socket::async_send)
      	[!_GLIBCXX_HAVE_SYS_SOCKET_H]: Likewise.
      	(basic_socket_acceptor::listen, basic_socket_acceptor::accept)
      	(basic_socket_acceptor::async_accept) [!_GLIBCXX_HAVE_SYS_SOCKET_H]:
      	Likewise.
      	(basic_socket_acceptor::wait) [!_GLIBCXX_HAVE_POLL_H]: Likewise.
      
      From-SVN: r265203
      Jonathan Wakely committed
    • Use effective target in Networking TS tests · 7e8b87e9
      	* testsuite/experimental/net/headers.cc: Remove dg-options.
      	* testsuite/experimental/net/buffer/arithmetic.cc: Replace dg-options
      	with dg-do using effective target.
      	* testsuite/experimental/net/buffer/const.cc: Likewise.
      	* testsuite/experimental/net/buffer/creation.cc: Likewise.
      	* testsuite/experimental/net/buffer/mutable.cc: Likewise.
      	* testsuite/experimental/net/buffer/size.cc: Likewise.
      	* testsuite/experimental/net/buffer/traits.cc: Likewise.
      	* testsuite/experimental/net/execution_context/use_service.cc:
      	Likewise.
      	* testsuite/experimental/net/internet/address/v4/comparisons.cc:
      	Likewise.
      	* testsuite/experimental/net/internet/address/v4/cons.cc: Likewise.
      	* testsuite/experimental/net/internet/address/v4/creation.cc:
      	Likewise.
      	* testsuite/experimental/net/internet/address/v4/members.cc: Likewise.
      	* testsuite/experimental/net/internet/resolver/base.cc: Likewise.
      	* testsuite/experimental/net/internet/resolver/ops/lookup.cc:
      	Likewise.
      	* testsuite/experimental/net/internet/resolver/ops/reverse.cc:
      	Likewise.
      	* testsuite/experimental/net/timer/waitable/cons.cc: Likewise.
      	* testsuite/experimental/net/timer/waitable/dest.cc: Likewise.
      	* testsuite/experimental/net/timer/waitable/ops.cc: Likewise.
      
      From-SVN: r265200
      Jonathan Wakely committed
    • Add missing return · 345fba60
      	* include/experimental/socket (basic_socket::at_mark): Add missing
      	return.
      
      From-SVN: r265199
      Jonathan Wakely committed
    • Define _GLIBCXX_USE_DEV_RANDOM as replacement for _GLIBCXX_USE_RANDOM_TR1 · 5ae2c32a
      Define and use a new macro with a more descriptive name. Only use the
      old macro in <tr1/random.h>.
      
      	* acinclude.m4 (GLIBCXX_CHECK_RANDOM_TR1): Replace with ...
      	(GLIBCXX_CHECK_DEV_RANDOM): New macro with more descriptive name.
      	Define _GLIBCXX_USE_DEV_RANDOM as well as _GLIBCXX_USE_RANDOM_TR1.
      	* config.h.in: Regenerate.
      	* configure: Regenerate.
      	* configure.ac: Use GLIBCXX_CHECK_DEV_RANDOM instead of
      	GLIBCXX_CHECK_RANDOM_TR1.
      	crossconfig.m4: Likewise.
      	* include/bits/random.h (random_device): Use _GLIBCXX_USE_DEV_RANDOM
      	instead of _GLIBCXX_USE_RANDOM_TR1.
      	* testsuite/26_numerics/random/random_device/cons/token.cc: Likewise.
      
      From-SVN: r265197
      Jonathan Wakely committed
    • Introduce dg-add-options net_ts · 630f2da9
      	* testsuite/lib/dg-options.exp (add_options_for_net_ts): New proc.
      	* testsuite/experimental/net/internet/address/v4/comparisons.cc:
      	Add dg-add-options net_ts.
      	* testsuite/experimental/net/internet/address/v4/cons.cc: Likewise.
      	* testsuite/experimental/net/internet/address/v4/creation.cc: Likewise.
      	* testsuite/experimental/net/internet/address/v4/members.cc: Likewise.
      	* testsuite/experimental/net/internet/resolver/base.cc: Likewise.
      	* testsuite/experimental/net/internet/resolver/ops/lookup.cc: Likewise.
      	* testsuite/experimental/net/internet/resolver/ops/reverse.cc: Likewise.
      
      From-SVN: r265192
      Rainer Orth committed
    • Fix tests that fail when compiled without optimisation · b57d432b
      	* testsuite/20_util/duration/literals/range_neg.cc: Adjust pruned
      	diagnostic to account for quotes around 'constexpr'.
      	* testsuite/23_containers/deque/capacity/max_size.cc: Define static
      	variable.
      	* testsuite/23_containers/vector/capacity/max_size.cc: Likewise.
      
      From-SVN: r265190
      Jonathan Wakely committed
    • PR libstdc++/87618 fix typos in linker script · d30096b4
      	PR libstdc++/87618
      	* config/abi/pre/gnu.ver: Fix typos in patterns for basic_stringbuf.
      	* testsuite/27_io/basic_stringbuf/cons/char/default.cc: Disable
      	optimisation to check constructor definition can be linked to.
      	* testsuite/27_io/basic_stringbuf/cons/wchar_t/default.cc: Likewise.
      
      From-SVN: r265188
      Jonathan Wakely committed
    • fixincludes: vxworks: regs.h: Fix includes in regs.h wrapper · 92a7f46b
      A quick experiment reveals that this hack is needed for C code - simply
      removing this hack entirely breaks the build of libstdc++, since
      regs.h (more accurately, the cpu-specific header it pulls in) defines
      structs in terms of types from vxTypesOld. Those definitions are
      properly guarded by #ifndef _ASMLANGUAGE, but the cpu-files do not take
      care to include vxTypesOld.h for the types they depend on.
      
      But when using regs.h from some assembly file, the assembler chokes on
      the typedefs in vxTypesOld.h. We can fix that by guarding the include of
      vxTypesOld by !_ASMLANGUAGE. This should not affect existing C code.
      
      Now, the OS' regs.h contains preprocessor conditionals such as
      
      #if     CPU_FAMILY==I960
      ...
      #endif  /* CPU_FAMILY==I960 */
      #if     CPU_FAMILY==MC680X0
      ...
      #endif  /* CPU_FAMILY==MC680X0 */
      
      Without definitions of CPU_FAMILY, I960 etc., these would all be true,
      which will not end well. Code using the fix-included regs.h
      automatically get vxCpu.h via a chain of includes from vxTypesOld.h, but
      we can make regs.h a little more self-contained for both C and asm users
      by doing an explicit include of vxCpu.h.
      
      From-SVN: r265187
      Rasmus Villemoes committed
    • Obsolete Solaris 10 support · ca3a27b6
      	contrib:
      	* config-list.mk (LIST): Switch to i686-solaris2.11,
      	sparc64-sun-solaris2.11.
      
      	gcc:
      	* config.gcc: Obsolete *-*-solaris2.10*.
      	* doc/install.texi (Specific, *-*-solaris2*): Document it.
      
      From-SVN: r265186
      Rainer Orth committed
    • Daily bump. · 7bb031ed
      From-SVN: r265183
      GCC Administrator committed
  4. 15 Oct, 2018 4 commits
    • ft32.md (ft32_general_movsrc_operand): Disable reg + sym +- const_int addressing modes. · 95debbf1
      	* config/ft32/ft32.md (ft32_general_movsrc_operand): Disable
      	reg + sym +- const_int addressing modes.
      
      From-SVN: r265179
      Jeff Law committed
    • diagnostics: add minimum width to left margin for line numbers · 0141ab44
      This patch adds a minimum width to the left margin used for printing
      line numbers.   I set the default to 6.  Hence rather than:
      
      some-filename:9:1: some message
      9 | some source text
        | ^~~~~~~~~~~~~~~~
      some-filename:10:1: another message
      10 | more source text
         | ^~~~~~~~~~~~~~~~
      
      we now print:
      
      some-filename:9:42: some message
          9 | some source text
            | ^~~~~~~~~~~~~~~~
      some-filename:10:42: another message
         10 | more source text
            | ^~~~~~~~~~~~~~~~
      
      This implicitly fixes issues with margins failing to line up due
      to different lengths of the number when we haven't read the full
      file yet and so don't know the highest possible line number, for
      line numbers up to 99999.
      
      Doing so adds some whitespace on the left-hand side, for non-huge
      files, at least.  I believe that this makes it easier to see where each
      diagnostic starts, by visually breaking things up at the leftmost
      column; my hope is to make it easier for the eye to see the different
      diagnostics as if they were different "paragraphs".
      
      gcc/ChangeLog:
      	* common.opt (fdiagnostics-minimum-margin-width=): New option.
      	* diagnostic-show-locus.c (layout::layout): Apply the minimum
      	margin width.
      	(layout::start_annotation_line): Only print up to 3 of the
      	margin character, to avoid touching the left-hand side.
      	(selftest::test_diagnostic_show_locus_fixit_lines): Update for
      	minimum margin width, as set by test_diagnostic_context's ctor.
      	(selftest::test_fixit_insert_containing_newline): Likewise.
      	(selftest::test_fixit_insert_containing_newline_2): Likewise.
      	(selftest::test_line_numbers_multiline_range): Clear
      	dc.min_margin_width.
      	* diagnostic.c (diagnostic_initialize): Initialize
      	min_margin_width.
      	* diagnostic.h (struct diagnostic_context): Add field
      	"min_margin_width".
      	* doc/invoke.texi: Add -fdiagnostics-minimum-margin-width=.
      	* opts.c (common_handle_option): Handle
      	OPT_fdiagnostics_minimum_margin_width_.
      	* selftest-diagnostic.c
      	(selftest::test_diagnostic_context::test_diagnostic_context):
      	Initialize min_margin_width to 6.
      	* toplev.c (general_init): Initialize global_dc->min_margin_width.
      
      gcc/testsuite/ChangeLog:
      	* gcc.dg/missing-header-fixit-3.c: Update expected indentation
      	to reflect minimum margin width.
      	* gcc.dg/missing-header-fixit-4.c: Likewise.
      	* gcc.dg/plugin/diagnostic-test-show-locus-bw-line-numbers.c:
      	Likewise.
      	* gcc.dg/plugin/diagnostic-test-show-locus-color-line-numbers.c:
      	Likewise.
      	* gcc.dg/plugin/diagnostic-test-show-locus-bw-line-numbers-2.c:
      	New test.
      	* gcc.dg/plugin/plugin.exp (plugin_test_list): Add it.
      
      From-SVN: r265178
      David Malcolm committed
    • Remove stray reference to error_at_rich_loc · 95baaced
      "error_at_rich_loc" went away in r254280 (in favor of overloading
      "error_at"), but there was a stray reference in a comment.
      
      Remove it.
      
      gcc/ChangeLog:
      	* gcc-rich-location.h (gcc_rich_location::add_location_if_nearby):
      	Fix usage of "error_at_rich_loc" in the comment.
      
      From-SVN: r265177
      David Malcolm committed
    • re PR fortran/87597 (wrong result with matmul inlining) · 91fe8d06
      2018-10-15  Tobias Burnus  <burnus@net-b.de>
      
             PR fortran/87597
             * gfortran.dg/inline_matmul_24.f90: Tweak scan-tree.
      
      From-SVN: r265175
      Tobias Burnus committed