We skip over other conversion codes when mangling expressions, we should do the same with IMPLICIT_CONV_EXPR.
Tested x86_64-pc-linux-gnu, applying to trunk/9/8. gcc/cp/ChangeLog 2020-04-04 Jason Merrill <ja...@redhat.com> PR c++/91377 * mangle.c (write_expression): Skip IMPLICIT_CONV_EXPR. --- gcc/cp/mangle.c | 1 + gcc/testsuite/g++.dg/abi/mangle75.C | 13 +++++++++++++ 2 files changed, 14 insertions(+) create mode 100644 gcc/testsuite/g++.dg/abi/mangle75.C diff --git a/gcc/cp/mangle.c b/gcc/cp/mangle.c index 1fc78bfa753..9e39cfd8dba 100644 --- a/gcc/cp/mangle.c +++ b/gcc/cp/mangle.c @@ -2875,6 +2875,7 @@ write_expression (tree expr) /* Skip NOP_EXPR and CONVERT_EXPR. They can occur when (say) a pointer argument is converted (via qualification conversions) to another type. */ while (CONVERT_EXPR_CODE_P (code) + || code == IMPLICIT_CONV_EXPR || location_wrapper_p (expr) /* Parentheses aren't mangled. */ || code == PAREN_EXPR diff --git a/gcc/testsuite/g++.dg/abi/mangle75.C b/gcc/testsuite/g++.dg/abi/mangle75.C new file mode 100644 index 00000000000..f2661997a33 --- /dev/null +++ b/gcc/testsuite/g++.dg/abi/mangle75.C @@ -0,0 +1,13 @@ +// PR c++/91377 +// { dg-do compile { target c++11 } } + +struct f { + static constexpr int d = 3; + typedef int e; +}; +template <int a> struct x { }; +template <typename g, g j, g m> using n = x<j + m>; +template <typename ac> auto v() -> n<typename ac::e, 0, ac::d>; +void af() { v<f>(); } + +// { dg-final { scan-assembler "_Z1vI1fE1xIXplLi0EsrT_1dEEv" } } base-commit: 21e28527130a89491f848dfb5019afa01b252479 -- 2.18.1