From: Jakub Jelinek Date: Tue, 5 Feb 2019 09:17:18 +0000 (+0100) Subject: re PR target/89186 (ICE in mark_addressable at gcc/gimple-expr.c:894 since r268138) X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=c8010d70be43ae96908bb82000518e03b5b65829;p=gcc.git re PR target/89186 (ICE in mark_addressable at gcc/gimple-expr.c:894 since r268138) PR target/89186 * optabs.c (prepare_cmp_insn): Pass x and y to emit_block_comp_via_libcall rather than XEXP (x, 0) and XEXP (y, 0). * g++.dg/ext/vector36.C: New test. From-SVN: r268531 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index f7c8b50e142..76a3e18b21c 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2019-02-05 Jakub Jelinek + + PR target/89186 + * optabs.c (prepare_cmp_insn): Pass x and y to + emit_block_comp_via_libcall rather than XEXP (x, 0) and XEXP (y, 0). + 2019-02-05 Richard Biener PR middle-end/89150 diff --git a/gcc/optabs.c b/gcc/optabs.c index ecda620c161..f2ca4359162 100644 --- a/gcc/optabs.c +++ b/gcc/optabs.c @@ -3917,7 +3917,7 @@ prepare_cmp_insn (rtx x, rtx y, enum rtx_code comparison, rtx size, goto fail; /* Otherwise call a library function. */ - result = emit_block_comp_via_libcall (XEXP (x, 0), XEXP (y, 0), size); + result = emit_block_comp_via_libcall (x, y, size); x = result; y = const0_rtx; diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 8a77c005c3b..51879b8ec3c 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2019-02-05 Jakub Jelinek + + PR target/89186 + * g++.dg/ext/vector36.C: New test. + 2019-02-05 Alexandre Oliva PR c++/87770 diff --git a/gcc/testsuite/g++.dg/ext/vector36.C b/gcc/testsuite/g++.dg/ext/vector36.C new file mode 100644 index 00000000000..b637f08a4fb --- /dev/null +++ b/gcc/testsuite/g++.dg/ext/vector36.C @@ -0,0 +1,6 @@ +// PR target/89186 +// { dg-do compile } +// { dg-options "-fnon-call-exceptions" } +// { dg-additional-options "-mno-sse" { target i?86-*-* x86_64-*-* } } + +#include "vector27.C"