From: Jason Merrill Date: Wed, 4 Mar 2020 22:30:58 +0000 (-0500) Subject: c++: avoid ICE with __builtin_memset (PR90997). X-Git-Tag: releases/gcc-9.3.0~30 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=831d4a690053599d2d0aa9713642b8513fdf8f5b;p=thirdparty%2Fgcc.git c++: avoid ICE with __builtin_memset (PR90997). warn_for_memset calls fold_for_warn, which calls fold_non_dependent_expr, so also calling instantiate_non_dependent_expr here is undesirable. gcc/cp/ChangeLog 2020-03-04 Jason Merrill PR c++/90997 * semantics.c (finish_call_expr): Don't call instantiate_non_dependent_expr before warn_for_memset. --- diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 614844ef9061..da873dad1b54 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,9 @@ +2020-03-04 Jason Merrill + + PR c++/90997 + * semantics.c (finish_call_expr): Don't call + instantiate_non_dependent_expr before warn_for_memset. + 2020-03-02 Jason Merrill PR c++/86917 diff --git a/gcc/cp/semantics.c b/gcc/cp/semantics.c index 0c727eaf2e73..4bfb5d152934 100644 --- a/gcc/cp/semantics.c +++ b/gcc/cp/semantics.c @@ -2577,7 +2577,6 @@ finish_call_expr (tree fn, vec **args, bool disallow_virtual, tree arg2 = (*orig_args)[2]; int literal_mask = ((literal_integer_zerop (arg1) << 1) | (literal_integer_zerop (arg2) << 2)); - arg2 = instantiate_non_dependent_expr (arg2); warn_for_memset (input_location, arg0, arg2, literal_mask); } diff --git a/gcc/testsuite/g++.dg/ext/builtin14.C b/gcc/testsuite/g++.dg/ext/builtin14.C new file mode 100644 index 000000000000..38d5a39fd73d --- /dev/null +++ b/gcc/testsuite/g++.dg/ext/builtin14.C @@ -0,0 +1,4 @@ +// PR c++/90997 + +template void f () +{ __builtin_memset (0, 0, int(0.)); }