From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: by sourceware.org (Postfix, from userid 1873) id 17F8C385E83F; Mon, 21 Mar 2022 19:56:51 +0000 (GMT) DKIM-Filter: OpenDKIM Filter v2.11.0 sourceware.org 17F8C385E83F MIME-Version: 1.0 Content-Transfer-Encoding: 7bit Content-Type: text/plain; charset="utf-8" From: Iain Buclaw To: gcc-cvs@gcc.gnu.org Subject: [gcc r12-7738] d: Fix internal compiler error: in build_complex, at tree.c:2358 X-Act-Checkin: gcc X-Git-Author: Iain Buclaw X-Git-Refname: refs/heads/master X-Git-Oldrev: fbdaa58162ee4189f441b75170af89215465d189 X-Git-Newrev: 1dd51373a82408361068e130a84caa888ef0d2b3 Message-Id: <20220321195651.17F8C385E83F@sourceware.org> Date: Mon, 21 Mar 2022 19:56:51 +0000 (GMT) X-BeenThere: gcc-cvs@gcc.gnu.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: Gcc-cvs mailing list List-Unsubscribe: , List-Archive: List-Help: List-Subscribe: , X-List-Received-Date: Mon, 21 Mar 2022 19:56:51 -0000 https://gcc.gnu.org/g:1dd51373a82408361068e130a84caa888ef0d2b3 commit r12-7738-g1dd51373a82408361068e130a84caa888ef0d2b3 Author: Iain Buclaw Date: Mon Mar 21 19:47:50 2022 +0100 d: Fix internal compiler error: in build_complex, at tree.c:2358 The conversion from the special _Complex enum to native complex used build_complex, however the input value isn't necessarily a literal. PR d/105004 gcc/d/ChangeLog: * d-codegen.cc (build_struct_literal): Use complex_expr to build complex expressions from __c_complex types. gcc/testsuite/ChangeLog: * gdc.dg/pr105004.d: New test. Diff: --- gcc/d/d-codegen.cc | 2 +- gcc/testsuite/gdc.dg/pr105004.d | 14 ++++++++++++++ 2 files changed, 15 insertions(+), 1 deletion(-) diff --git a/gcc/d/d-codegen.cc b/gcc/d/d-codegen.cc index 3e54d3bffd0..3206edd17e8 100644 --- a/gcc/d/d-codegen.cc +++ b/gcc/d/d-codegen.cc @@ -1161,7 +1161,7 @@ build_struct_literal (tree type, vec *init) if (COMPLEX_FLOAT_TYPE_P (type)) { gcc_assert (vec_safe_length (init) == 2); - return build_complex (type, (*init)[0].value, (*init)[1].value); + return complex_expr (type, (*init)[0].value, (*init)[1].value); } vec *ve = NULL; diff --git a/gcc/testsuite/gdc.dg/pr105004.d b/gcc/testsuite/gdc.dg/pr105004.d new file mode 100644 index 00000000000..60b3c3f635e --- /dev/null +++ b/gcc/testsuite/gdc.dg/pr105004.d @@ -0,0 +1,14 @@ +// https://gcc.gnu.org/bugzilla/show_bug.cgi?id=105004 +// { dg-do compile } + +private struct _Complex(T) +{ + T re; + T im; +} +enum __c_complex_float : _Complex!float; + +__c_complex_float pr105004(float re, float im) +{ + return typeof(return)(re, im); +}