1. 21 Sep, 2017 24 commits
    • [demangler PATCH]: Revert and update generic lambda demangling · 7cd7dbda
      https://gcc.gnu.org/ml/gcc-patches/2017-09/msg01482.html
      	PR demangler/82195
      	* cp-demangle.c (d_name): Revert addition of 'toplevel' parm.
      	(has_return_type): Recurse for DEMANGLE_COMPONENT_LOCAL_NAME.
      	(d_encoding): Revert d_name change.  Use is_fnqual_component_type
      	to strip modifiers that do not belong.
      	(d_special_name, d_class_enum_type): Revert d_name call change.
      	(d_expresion_1): Commonize DEMANGLE_COMPONENT_UNARY building.
      	(d_local_name): Revert parsing of a function type.
      	(d_print_comp_inner): An inner LOCAL_NAME might contain a
      	TEMPLATE.
      	* testsuite/demangle-expected: Add & adjust tests
      
      From-SVN: r253075
      Nathan Sidwell committed
    • re PR testsuite/78421 (vect-strided-a-u8-i2-gap.c fails on armeb) · 65d8c94d
      2017-09-21  Tamar Christina  <tamar.christina@arm.com>
      
      	PR testsuite/78421
      	* lib/target-supports.exp (check_effective_target_vect_hw_misalign):
      	Invert arm check.
      
      From-SVN: r253073
      Tamar Christina committed
    • Rename existing insn_cost to insn_sched_cost · ffc1ded5
      haifa-sched exports an insn_cost function, but it is only used in a
      few places and specialised to scheduling.  This patch renames it to
      insn_sched_cost.
      
      
      	* haifa-sched.c: Rename insn_cost to insn_sched_cost.
      	* sched-rgn.c: Ditto.
      	* sel-sched-ir.c: Ditto.
      
      From-SVN: r253072
      Segher Boessenkool committed
    • openmp.c (gfc_match_oacc_wait): Don't restrict wait directive arguments to constant integers. · a0e27dc2
      	gcc/fortran/
      	* openmp.c (gfc_match_oacc_wait): Don't restrict wait directive
      	arguments to constant integers.
      
      	gcc/testsuite/
      	* gfortran.dg/goacc/wait.f90: New test.
      
      From-SVN: r253071
      Cesar Philippidis committed
    • toplev: read from /dev/urandom only when needed · edabe3d8
      	* toplev.h (set_random_seed): Adjust return type.
      	* toplev.c (init_local_tick): Move eager initialization of random_seed
      	to get_random_seed.  Adjust comment.
      	(init_random_seed): Inline to get_random_seed, delete.
      	(get_random_seed): Initialize random_seed lazily.
      	(set_random_seed): Do not return previous value.
      	(print_switch_value): Do not call get_random_seed.
      
      From-SVN: r253069
      Alexander Monakov committed
    • ipa: fix dumping with deleted multiversioning nodes · 9acb4592
      2017-09-21  Evgeny Kudryashov <kudryashov@ispras.ru>
      
      	* cgraph.c (delete_function_version): New, broken out from...
      	(cgraph_node::delete_function_version): ...here.  Rename to
      	cgraph_node::delete_function_version_by_decl.  Update all uses.
      	(cgraph_node::remove): Call delete_function_version.
      
      From-SVN: r253066
      Evgeny Kudryashov committed
    • re PR sanitizer/81715 (asan-stack=1 redzone allocation is too inflexible) · 765b3379
      	PR sanitizer/81715
      	* tree-inline.c (expand_call_inline): Emit clobber stmts for
      	VAR_DECLs to which addressable non-volatile parameters are mapped
      	and for id->retvar after the return value assignment.  Clear
      	id->retval and id->retbnd after inlining.
      
      	* g++.dg/tree-ssa/pr8781.C (noop): Change argument type from
      	const predicate to const predicate & to avoid UB.
      	* g++.dg/opt/pr81715.C: New test.
      
      From-SVN: r253065
      Jakub Jelinek committed
    • re PR tree-optimization/82276 (-O2: ICE: SSA corruption during RTL pass: expand;… · c94f2d84
      re PR tree-optimization/82276 (-O2: ICE: SSA corruption during RTL pass: expand; at tree-ssa-coalesce.c:1010)
      
      2017-09-21  Richard Biener  <rguenther@suse.de>
      
      	PR tree-optimization/82276
      	PR tree-optimization/82244
      	* tree-vrp.c (build_assert_expr_for): Set
      	SSA_NAME_OCCURS_IN_ABNORMAL_PHI if the variable we assert on
      	has it set.
      	(remove_range_assertions): Revert earlier change.
      
      	* gcc.dg/torture/pr82276.c: New testcase.
      
      From-SVN: r253062
      Richard Biener committed
    • PR71951: Fix unwinding with -fomit-frame-pointer · 817221cc
      As described in PR71951, if libgcc is built with -fomit-frame-pointer,
      unwinding crashes, for example while doing a backtrace.  The underlying
      reason is the Dwarf unwinder does not setup the frame pointer register
      in the initialization code.  When later unwinding a function that uses
      the frame pointer, it tries to read FP using _Unwind_GetGR, and this
      crashes if has never restored FP.  To unwind correctly the first frame
      must save and restore FP (it is unwound in a special way so that it
      uses SP instead of FP).  This is done by adding -fno-omit-frame-pointer.
      
          gcc/
      	PR target/71951
      	* config/aarch64/aarch64.h (LIBGCC2_UNWIND_ATTRIBUTE): Define.
      
      From-SVN: r253061
      Wilco Dijkstra committed
    • graphite-isl-ast-to-gimple.c (graphite_regenerate_ast_isl): Restore valid IL… · 73d1c650
      graphite-isl-ast-to-gimple.c (graphite_regenerate_ast_isl): Restore valid IL after code generation errors.
      
      2017-09-21  Richard Biener  <rguenther@suse.de>
      
      	* graphite-isl-ast-to-gimple.c (graphite_regenerate_ast_isl):
      	Restore valid IL after code generation errors.
      	* graphite.c (graphite_transform_loops): Diagnose code
      	generation issues as MSG_MISSED_OPTIMIZATION and continue
      	with processing SCOPs.
      
      From-SVN: r253060
      Richard Biener committed
    • Make more use of simplify_gen_binary · a708f4b6
      This patch replaces various places that previously used:
      
        if (GET_CODE (y) == CONST_INT)
          ... plus_constant (..., x, [-]INTVAL (y)) ...
        else
          ... gen_rtx_PLUS/MINUS (..., x, y) ...
      
      with single calls to simplify_gen_binary.  This allows
      them to handle polynomial integers as well as constants.
      
      2017-09-21  Richard Sandiford  <richard.sandiford@linaro.org>
      	    Alan Hayward  <alan.hayward@arm.com>
      	    David Sherwood  <david.sherwood@arm.com>
      
      gcc/
      	* calls.c (compute_argument_addresses): Use simplify_gen_binary
      	rather than choosing between plus_constant and gen_rtx_<CODE>.
      	* expr.c (emit_push_insn): Likewise.
      	(expand_expr_real_2): Likewise.
      
      Co-Authored-By: Alan Hayward <alan.hayward@arm.com>
      Co-Authored-By: David Sherwood <david.sherwood@arm.com>
      
      From-SVN: r253059
      Richard Sandiford committed
    • Add copy_rtx call to RTL loop unroller · 6b1237e3
      This is needed if the step is an unshared constant, like many
      (const ...)s are.  Without this patch, libgfortran would fail
      to build for SVE.
      
      2017-09-21  Richard Sandiford  <richard.sandiford@linaro.org>
      	    Alan Hayward  <alan.hayward@arm.com>
      	    David Sherwood  <david.sherwood@arm.com>
      
      gcc/
      	* loop-unroll.c (split_iv): Call copy_rtx on the step.
      
      Co-Authored-By: Alan Hayward <alan.hayward@arm.com>
      Co-Authored-By: David Sherwood <david.sherwood@arm.com>
      
      From-SVN: r253058
      Richard Sandiford committed
    • Fix unguarded uses of tree_to_uhwi · 2e89be48
      This patch uses tree_fits_uhwi_p to protect a previously unguarded
      use of tree_to_uhwi.  Previously we would ICE for variable-sized types.
      
      2017-09-20  Richard Sandiford  <richard.sandiford@linaro.org>
      	    Alan Hayward  <alan.hayward@arm.com>
      	    David Sherwood  <david.sherwood@arm.com>
      
      gcc/
      	* tree.c (find_atomic_core_type): Check tree_fits_uhwi_p before
      	calling tree_to_uhwi.
      
      Co-Authored-By: Alan Hayward <alan.hayward@arm.com>
      Co-Authored-By: David Sherwood <david.sherwood@arm.com>
      
      From-SVN: r253057
      Richard Sandiford committed
    • Tighten tree-ssa-ccp.c:get_value_for_expr condition · 4a77e887
      bit_value_unop and bit_value_binop require constant values
      to be INTEGER_CSTs:
      
        gcc_assert ((rval.lattice_val == CONSTANT
                     && TREE_CODE (rval.value) == INTEGER_CST)
                    || wi::sext (rval.mask, TYPE_PRECISION (TREE_TYPE (rhs))) == -1);
      
      However, when deciding whether to record a constant value,
      the for_bits_p handling in get_value_for_expr used a negative
      test for ADDR_EXPR:
      
        else if (is_gimple_min_invariant (expr)
                 && (!for_bits_p || TREE_CODE (expr) != ADDR_EXPR))
      
      This patch uses a positive test for INTEGER_CST instead.
      
      Existing tests showed the need for this once polynomial constants
      are added.
      
      2017-09-21  Richard Sandiford  <richard.sandiford@linaro.org>
      	    Alan Hayward  <alan.hayward@arm.com>
      	    David Sherwood  <david.sherwood@arm.com>
      
      gcc/
      	* tree-ssa-ccp.c (get_value_for_expr): Use a positive test for
      	INTEGER_CST rather than a negative test for ADDR_EXPR.
      
      Co-Authored-By: Alan Hayward <alan.hayward@arm.com>
      Co-Authored-By: David Sherwood <david.sherwood@arm.com>
      
      From-SVN: r253056
      Richard Sandiford committed
    • Tweak · dd72b5f9
      From-SVN: r253055
      Eric Botcazou committed
    • Add missing int_cst_rangeN checks to tree-vrp.c · 53cb6378
      The BIT_AND_EXPR handling in extract_range_from_binary_expr_1
      was using value_range_constant_singleton without first checking
      whether the range was a constant.  The earlier handling was correctly
      guarded:
      
      	  /* If either input range contains only non-negative values
      	     we can truncate the result range maximum to the respective
      	     maximum of the input range.  */
      	  if (int_cst_range0 && tree_int_cst_sgn (vr0.min) >= 0)
      	    wmax = wi::min (wmax, vr0.max, TYPE_SIGN (expr_type));
      	  if (int_cst_range1 && tree_int_cst_sgn (vr1.min) >= 0)
      	    wmax = wi::min (wmax, vr1.max, TYPE_SIGN (expr_type));
      
      so this patch uses the same guards again.
      
      Existing tests showed the need for this once polynomial constants
      are added.
      
      2017-09-21  Richard Sandiford  <richard.sandiford@linaro.org>
      	    Alan Hayward  <alan.hayward@arm.com>
      	    David Sherwood  <david.sherwood@arm.com>
      
      gcc/
      	* tree-vrp.c (extract_range_from_binary_expr_1): Check
      	int_cst_rangeN before calling value_range_constant_singleton (&vrN).
      
      Co-Authored-By: Alan Hayward <alan.hayward@arm.com>
      Co-Authored-By: David Sherwood <david.sherwood@arm.com>
      
      From-SVN: r253054
      Richard Sandiford committed
    • re PR tree-optimization/71351 (ICE: Segmentation fault (graphite)) · 2e1dd137
      2017-09-21  Richard Biener  <rguenther@suse.de>
      
      	PR tree-optimization/71351
      	* graphite-isl-ast-to-gimple.c (translate_isl_ast_to_gimple::
      	graphite_create_new_loop_guard): Remove, fold remaining parts
      	into caller ...
      	(translate_isl_ast_node_for): ... here and simplify.
      
      	* gfortran.dg/graphite/pr71351.f90: New testcase.
      	* gfortran.dg/graphite/interchange-3.f90: Adjust.
      
      From-SVN: r253052
      Richard Biener committed
    • Fix tests for std::clamp · f3f08c3f
      	* testsuite/25_algorithms/clamp/1.cc: Fix order of arguments and
      	expected results when using predicate defining reverse order.
      	* testsuite/25_algorithms/clamp/constexpr.cc: Likewise.
      
      From-SVN: r253051
      Jonathan Wakely committed
    • re PR target/82260 ([x86] Unnecessary use of 8-bit registers with -Os. slightly… · a4f65ca8
      re PR target/82260 ([x86] Unnecessary use of 8-bit registers with -Os.  slightly slower and larger code)
      
      	PR target/82260
      	* config/i386/i386.md (*movqi_internal): Replace (=q,q) alternative
      	with (=Q,Q), (=R,R) and (=r,r) alternatives, only enable the
      	latter two for 64-bit, renumber alternatives, for -Os imov (=q,n)
      	alternative always use QI mode, for -Os imov (=R,R) alternative
      	always use SI mode, for imov (=Q,Q) or (=r,r) alternatives
      	ignore -Os.
      
      	* gcc.target/i386/pr82260-1.c: New test.
      	* gcc.target/i386/pr82260-2.c: New test.
      
      From-SVN: r253050
      Jakub Jelinek committed
    • s390.c (MIN_UNROLL_PROBES): Define. · d3347cd2
      	* config/s390/s390.c (MIN_UNROLL_PROBES): Define.
      	(allocate_stack_space): New function, partially extracted from
      	s390_emit_prologue.
      	(s390_emit_prologue): Track offset to most recent stack probe.
      	Code to allocate space moved into allocate_stack_space.
      	Dump actions when no stack is allocated.
      	(s390_prologue_plus_offset): New function.
      	(s390_emit_stack_probe): Likewise.
      
      	* gcc.dg/stack-check-5.c:  Add argument for s390.
      	* lib/target-supports.exp:
      	(check_effective_target_supports_stack_clash_protection): Enable for
      	s390/s390x targets.
      
      Co-Authored-By: Jeff Law <law@redhat.com>
      
      From-SVN: r253049
      Andreas Krebbel committed
    • [C++ PATCH] class member ordering · 12f71313
      https://gcc.gnu.org/ml/gcc-patches/2017-09/msg01426.html
      	* name-lookup.c (member_name_cmp): Use DECL_UID for final
      	ordering.
      
      From-SVN: r253048
      Nathan Sidwell committed
    • enable handling of -gno- command-line options as negated prefixes · 9ed32e27
      This patch that adds -g to the set of negatable prefixes along with -f,
      -m and -W.  Besides the mapping from -gno- to negated -g in option_map
      and adding g to the [fmW] matches for negatable options, I had to
      introduce gno- as an remapping prefix, for the option searching
      machinery to backtrack to and recognize as a remapping prefix, instead
      of backtracking to -g and stopping at it as if no-* was its Joined
      argument.  Adding such remapping prefixes to preempt further
      backtracking can be accomplished by introducing the prefix as an
      Undocumented option with a Joined argument and without Driver, Target,
      Common, or any language-specific option.  Whenever we match such a fake
      options prefix, we abandon further backtracking (it matches, after all),
      but find_opt returns the same code it would if it hadn't found any
      match, so that we resort to option mapping.
      
      I've arranged for such remapping prefixes to not be considered when
      looking for and suggesting a correct spelling for misspelled options.
      While testing that, I found a few -W-started options that were not
      marked as RejectNegative but should (-Wno-a, is not something we'd like
      to suggest ;-)  I've also marked as such -g-started options that
      it makes no sense to negate, and removed the explicit -gno- ones,
      allowing their opposites to be negated.
      
      for  gcc/ChangeLog
      
      	* common.opt (Wa, Wl, Wp, g, gz=): Add
      	RejectNegative.
      	(gno-column-info): Remove.
      	(gcolumn-info): Drop RejectNegative.
      	(gno-): New prefix.
      	(gno-record-gcc-switches): Remove.
      	(grecord-gcc-switches): Drop RejectNegative.
      	(gno-split-dwarf): Remove.
      	(gsplit-dwarf): Drop RejectNegative.
      	(gno-strict-dwarf): Remove.
      	(gstrict-dwarf): Drop RejectNegative.
      	* config/darwin.opt (gfull, gused): Add RejectNegative.
      	* dwarf2out.c (gen_producer_string): Drop
      	gno-record-gcc-switches handler.
      	* optc-gen.awk: Add g to prefixes with negative forms.
      	* opts-common.c (remapping_prefix_p): New.
      	(find_opt): Check it.
      	(generate_canonical_option): Test g prefix.
      	(option_map): Add -gno- mapping.
      	(add_misspelling_candidates): Check remapping_prefix_p.
      
      for  gcc/ada/ChangeLog
      
      	* gcc-interface/lang.opt (gant, gnatO, gnat): Add
              RejectNegative.
      
      for  gcc/c-family/ChangeLog
      
      	* c.opt (gen-decls): Add RejectNegative.
      
      From-SVN: r253047
      Alexandre Oliva committed
    • Daily bump. · d8a61466
      From-SVN: r253046
      GCC Administrator committed
  2. 20 Sep, 2017 16 commits
    • libgo: fix build when using -enable-static=no · 7399e345
          
          With -enable-static=no we don't build non-pic objects, but libgotool.a
          is built from non-pic objects.  Build the packages that go into
          libgotool.a in static mode in all cases.
          
          Also ensure that internal test packages are built, since nothing
          explicitly depended on them.
          
          Reviewed-on: https://go-review.googlesource.com/65050
      
      From-SVN: r253042
      Ian Lance Taylor committed
    • Fix C++ testsuite fallout from r252976. · 073809a7
      gcc/testsuite/ChangeLog:
      
      	PR c/81854
      	* g++.dg/ext/attr-ifunc-2.C: Correct type errors.
      	* g++.dg/ext/attr-ifunc-4.C: Ditto.
      	* lib/target-supports.exp: Adjust for C++.
      
      From-SVN: r253041
      Martin Sebor committed
    • Fix testsuite fallout from r252976. · 5f2fd590
      gcc/testsuite/ChangeLog:
      
      	PR c/81854
      	* gcc.dg/attr-ifunc-1.c: Correct type errors.
      	* gcc.dg/attr-ifunc-2.c: Ditto.
      	* gcc.dg/attr-ifunc-3.c: Ditto.
      	* gcc.dg/attr-ifunc-4.c: Ditto.
      	* gcc.dg/attr-ifunc-5.c: Ditto.
      	* gcc.dg/pr81854.c: Require ifunc support.
      	* gcc/testsuite/lib/target-supports.exp: Correct type error.
      
      From-SVN: r253037
      Martin Sebor committed
    • powerpcspe.c (rs6000_expand_prologue): Fix thinko in stack clash protection support. · 329c9aee
      	* config/powerpcspe/powerpcspe.c (rs6000_expand_prologue): Fix
      	thinko in stack clash protection support.
      
      From-SVN: r253036
      Jeff Law committed
    • PR libstdc++/79162 Fix std::string regression due to LWG 2946 (old ABI) · 9d2bac69
      	PR libstdc++/79162
      	* include/bits/basic_string.h [!_GLIBCXX_USE_CXX11_ABI]
      	(basic_string::_If_sv): Remove from the overload set when the
      	argument is derived from basic_string.
      
      From-SVN: r253035
      Jonathan Wakely committed
    • explow.c (compute_stack_clash_protection_loop_data): Use CONST_INT_P instead of explicit test. · 94c23e39
      	* explow.c (compute_stack_clash_protection_loop_data): Use
      	CONST_INT_P instead of explicit test.  Verify object is a
      	CONST_INT_P before looking at INTVAL.
      	(anti_adjust_stack_and_probe_stack_clash): Use CONST_INT_P
      	instead of explicit test.
      
      	* gcc.target/i386/stack-check-11.c: Update test and regexp
      	so that it works for both i?86 and x86_64.
      
      From-SVN: r253034
      Jeff Law committed
    • rs6000: Don't touch below the stack pointer (PR77687) · 6073d002
      With the 32-bit SVR4 ABI we don't have a red zone, so we have to restore
      the callee-saved registers before we restore the stack pointer.
      
      The previous fix for this PR failed in two ways, for huge frames: first,
      we use a negative offset from r11 in that case, so the (mem:BLK 11) access
      does no good; second, sched does not handle accesses to mem:BLK correctly
      in this case (does not make dependencies).
      
      This patch fixes it by doing a store to (mem:BLK (scratch)) instead.
      This means no unrelated (not to stack) loads/stores can be moved over the
      stack restore either, but so be it.
      
      
      	PR target/77687
      	* config/rs6000/rs6000.md (stack_restore_tie): Store to a scratch
      	address instead of to r1 and r11.
      
      gcc/testsuite/
      	PR target/77687
      	* gcc.target/powerpc/pr77687.c: New testcase.
      
      From-SVN: r253033
      Segher Boessenkool committed
    • re PR sanitizer/77631 (no symbols in backtrace shown by ASan when debug info is split) · 9283471b
      	PR sanitizer/77631
      	Support for external debug info.
      	* elf.c: Include <errno.h>, <sys/stat.h>, <unistd.h>.
      	(S_ISLNK): Define if not defined.
      	(xstrnlen): Define if strnlen is not available.
      	(b_elf_note): Define type.
      	(NT_GNU_BUILD_ID): Define macro.
      	(elf_crc32, elf_crc32_file): New static functions.
      	(elf_is_symlink, elf_readlink): New static functions.
      	(elf_open_debugfile_by_buildid): New static function.
      	(elf_try_debugfile): New static function.
      	(elf_find_debugfile_by_debuglink): New static function.
      	(elf_open_debugfile_by_debuglink): New static function.
      	(elf_add): Add filename and debuginfo parameters.  Adjust all
      	callers.  Look for external debug info notes, and try to fetch
      	debug info from external file.
      	(struct phdr_data): Add exe_filename field.
      	(phdr_callback): Pass filename to elf_add.
      	(backtrace_initialize): Add filename parameter.
      	* internal.h (backtrace_initialize): Add filename parameter.
      	* fileline.c (fileline_initialize): Pass filename to
      	backtrace_initialize.
      	* pecoff.c (fileline_initialize): Add unused filename parameter.
      	* unknown.c (fileline_initialize): Likewise.
      	* xcoff.c (fileline_initialize): Likewise.
      	* configure.ac: Check for objcopy --add-gnu-debuglink.
      	* Makefile.am (dtest): New test target.
      	* configure, Makefile.in: Rebuild.
      
      Co-Authored-By: Denis Khalikov <d.khalikov@partner.samsung.com>
      
      From-SVN: r253032
      Ian Lance Taylor committed
    • P0409R2 - allow lambda capture [=, this] · 2ffb5745
      	P0409R2 - allow lambda capture [=, this]
      	* parser.c (cp_parser_lambda_introducer): For cxx2a don't pedwarn on
      	redundant [=, this].
      
      	* g++.dg/cpp1z/lambda-this1.C: Don't expect error for c++2a on [=, this]
      	capture.  Add further tests.
      	* g++.dg/cpp0x/lambda/lambda-capture-redundancy.C: Don't expect error
      	for c++2a on [=, this] capture.
      
      From-SVN: r253030
      Jakub Jelinek committed
    • cplusplus.C: Test that __cplusplus is equal to 201703L. · fb3cd39d
      	* g++.dg/cpp1z/cplusplus.C: Test that __cplusplus is equal to 201703L.
      	* g++.dg/cpp1z/cplusplus_1z.C: New test.
      
      From-SVN: r253029
      Jakub Jelinek committed
    • PR libstdc++/79162 Fix std::string regression due to LWG 2946 · 4cf5930f
      	PR libstdc++/79162
      	* include/bits/basic_string.h (basic_string::_If_sv): Remove from the
      	overload set when the argument is derived from basic_string.
      	* testsuite/21_strings/basic_string/cons/char/moveable2_c++17.cc: New
      	test.
      	* testsuite/21_strings/basic_string/cons/wchar_t/moveable2_c++17.cc:
      	New test.
      
      From-SVN: r253024
      Jonathan Wakely committed
    • syscall: enable ParseDirent for AIX · 836cccc7
          
          Reviewed-on: https://go-review.googlesource.com/64990
      
      From-SVN: r253022
      Ian Lance Taylor committed
    • Fix failing C++17 test · e18f68c7
      	* testsuite/24_iterators/range_access_cpp17.cc: Fix order of dg-do
      	and dg-options directives. Fix invalid test.
      
      From-SVN: r253019
      Jonathan Wakely committed
    • PR libstdc++/81469 deprecate std::uncaught_exception for C++17 · 95ed529d
      	PR libstdc++/81469
      	* libsupc++/exception (uncaught_exception): Deprecate for C++17.
      	* testsuite/18_support/exception_ptr/62258.cc: Add -Wno-deprecated.
      	* testsuite/18_support/uncaught_exception/14026.cc: Likewise.
      
      From-SVN: r253018
      Jonathan Wakely committed
    • Deprecate nested types in std::hash · f78958c9
      	* include/bits/c++config (_GLIBCXX17_DEPRECATED): Define.
      	* include/bits/functional_hash.h (__hash_base::result_type)
      	(__hash_base::argument_type): Add _GLIBCXX17_DEPRECATED.
      	* include/std/optional (hash<optional<T>>::result_type)
      	(hash<optional<T>>::argument_type): Add deprecated attribute.
      	(__is_fast_hash<hash<optional<T>>>): Add partial specialization.
      	* include/std/variant (hash<variant<Types...>>::result_type)
      	(hash<variant<Types...>>::argument_type): Add deprecated attribute.
      	(__is_fast_hash<hash<variant<Types...>>>): Add partial specialization.
      
      From-SVN: r253017
      Jonathan Wakely committed