mirror of git://gcc.gnu.org/git/gcc.git
re PR c++/12909 (ambiguity in mangling vector types)
PR c++/12909 * mangle.c (write_type) [VECTOR_TYPE]: Change mangling. From-SVN: r156481
This commit is contained in:
parent
07738b87c4
commit
abfe01cec9
|
|
@ -266,7 +266,13 @@ Common Separate
|
||||||
;
|
;
|
||||||
; 1: The version of the ABI first used in G++ 3.2.
|
; 1: The version of the ABI first used in G++ 3.2.
|
||||||
;
|
;
|
||||||
; 2: The version of the ABI first used in G++ 3.4.
|
; 2: The version of the ABI first used in G++ 3.4 (and current default).
|
||||||
|
;
|
||||||
|
; 3: The version of the ABI that fixes the missing underscore
|
||||||
|
; in template non-type arguments of pointer type.
|
||||||
|
;
|
||||||
|
; 4: The version of the ABI that introduces unambiguous mangling of
|
||||||
|
; vector types.
|
||||||
;
|
;
|
||||||
; Additional positive integers will be assigned as new versions of
|
; Additional positive integers will be assigned as new versions of
|
||||||
; the ABI become the default version of the ABI.
|
; the ABI become the default version of the ABI.
|
||||||
|
|
|
||||||
|
|
@ -1,3 +1,9 @@
|
||||||
|
2010-02-03 Jason Merrill <jason@redhat.com>
|
||||||
|
|
||||||
|
PR c++/12909
|
||||||
|
* mangle.c (write_type) [VECTOR_TYPE]: Change mangling with
|
||||||
|
-fabi-version=4.
|
||||||
|
|
||||||
2010-02-02 Jason Merrill <jason@redhat.com>
|
2010-02-02 Jason Merrill <jason@redhat.com>
|
||||||
|
|
||||||
PR c++/41090
|
PR c++/41090
|
||||||
|
|
|
||||||
|
|
@ -1850,7 +1850,16 @@ write_type (tree type)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case VECTOR_TYPE:
|
case VECTOR_TYPE:
|
||||||
write_string ("U8__vector");
|
if (abi_version_at_least (4))
|
||||||
|
{
|
||||||
|
write_string ("Dv");
|
||||||
|
/* Non-constant vector size would be encoded with
|
||||||
|
_ expression, but we don't support that yet. */
|
||||||
|
write_unsigned_number (TYPE_VECTOR_SUBPARTS (type));
|
||||||
|
write_char ('_');
|
||||||
|
}
|
||||||
|
else
|
||||||
|
write_string ("U8__vector");
|
||||||
write_type (TREE_TYPE (type));
|
write_type (TREE_TYPE (type));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,5 +1,8 @@
|
||||||
2010-02-03 Jason Merrill <jason@redhat.com>
|
2010-02-03 Jason Merrill <jason@redhat.com>
|
||||||
|
|
||||||
|
PR c++/12909
|
||||||
|
* g++.dg/abi/mangle36.C: New.
|
||||||
|
|
||||||
PR c++/35652
|
PR c++/35652
|
||||||
* g++.dg/warn/string1.C: New.
|
* g++.dg/warn/string1.C: New.
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,9 @@
|
||||||
|
// PR c++/41959
|
||||||
|
// { dg-do compile { target i?86-*-* x86_64-*-* } }
|
||||||
|
// { dg-options "-mavx -fabi-version=4" }
|
||||||
|
// { dg-final { scan-assembler "_Z1fDv4_f" } }
|
||||||
|
// { dg-final { scan-assembler "_Z1fDv8_f" } }
|
||||||
|
|
||||||
|
#include <x86intrin.h>
|
||||||
|
void f(__m128) { }
|
||||||
|
void f(__m256) { }
|
||||||
|
|
@ -326,6 +326,9 @@ enum demangle_component_type
|
||||||
DEMANGLE_COMPONENT_PTRMEM_TYPE,
|
DEMANGLE_COMPONENT_PTRMEM_TYPE,
|
||||||
/* A fixed-point type. */
|
/* A fixed-point type. */
|
||||||
DEMANGLE_COMPONENT_FIXED_TYPE,
|
DEMANGLE_COMPONENT_FIXED_TYPE,
|
||||||
|
/* A vector type. The left subtree is the number of elements,
|
||||||
|
the right subtree is the element type. */
|
||||||
|
DEMANGLE_COMPONENT_VECTOR_TYPE,
|
||||||
/* An argument list. The left subtree is the current argument, and
|
/* An argument list. The left subtree is the current argument, and
|
||||||
the right subtree is either NULL or another ARGLIST node. */
|
the right subtree is either NULL or another ARGLIST node. */
|
||||||
DEMANGLE_COMPONENT_ARGLIST,
|
DEMANGLE_COMPONENT_ARGLIST,
|
||||||
|
|
@ -378,6 +381,8 @@ enum demangle_component_type
|
||||||
DEMANGLE_COMPONENT_COMPOUND_NAME,
|
DEMANGLE_COMPONENT_COMPOUND_NAME,
|
||||||
/* A name formed by a single character. */
|
/* A name formed by a single character. */
|
||||||
DEMANGLE_COMPONENT_CHARACTER,
|
DEMANGLE_COMPONENT_CHARACTER,
|
||||||
|
/* A number. */
|
||||||
|
DEMANGLE_COMPONENT_NUMBER,
|
||||||
/* A decltype type. */
|
/* A decltype type. */
|
||||||
DEMANGLE_COMPONENT_DECLTYPE,
|
DEMANGLE_COMPONENT_DECLTYPE,
|
||||||
/* Global constructors keyed to name. */
|
/* Global constructors keyed to name. */
|
||||||
|
|
|
||||||
|
|
@ -1,3 +1,9 @@
|
||||||
|
2010-02-03 Jason Merrill <jason@redhat.com>
|
||||||
|
|
||||||
|
PR c++/12909
|
||||||
|
* cp-demangle.c (d_number_component, d_vector_type): New.
|
||||||
|
(cplus_demangle_type, d_print_comp, d_print_mod): Handle vectors.
|
||||||
|
|
||||||
2010-01-25 Ian Lance Taylor <iant@google.com>
|
2010-01-25 Ian Lance Taylor <iant@google.com>
|
||||||
|
|
||||||
* cp-demangle.c (cplus_demangle_type): Check for invalid type
|
* cp-demangle.c (cplus_demangle_type): Check for invalid type
|
||||||
|
|
|
||||||
|
|
@ -389,6 +389,8 @@ d_class_enum_type (struct d_info *);
|
||||||
|
|
||||||
static struct demangle_component *d_array_type (struct d_info *);
|
static struct demangle_component *d_array_type (struct d_info *);
|
||||||
|
|
||||||
|
static struct demangle_component *d_vector_type (struct d_info *);
|
||||||
|
|
||||||
static struct demangle_component *
|
static struct demangle_component *
|
||||||
d_pointer_to_member_type (struct d_info *);
|
d_pointer_to_member_type (struct d_info *);
|
||||||
|
|
||||||
|
|
@ -796,6 +798,7 @@ d_make_comp (struct d_info *di, enum demangle_component_type type,
|
||||||
case DEMANGLE_COMPONENT_LITERAL:
|
case DEMANGLE_COMPONENT_LITERAL:
|
||||||
case DEMANGLE_COMPONENT_LITERAL_NEG:
|
case DEMANGLE_COMPONENT_LITERAL_NEG:
|
||||||
case DEMANGLE_COMPONENT_COMPOUND_NAME:
|
case DEMANGLE_COMPONENT_COMPOUND_NAME:
|
||||||
|
case DEMANGLE_COMPONENT_VECTOR_TYPE:
|
||||||
if (left == NULL || right == NULL)
|
if (left == NULL || right == NULL)
|
||||||
return NULL;
|
return NULL;
|
||||||
break;
|
break;
|
||||||
|
|
@ -1442,6 +1445,20 @@ d_number (struct d_info *di)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Like d_number, but returns a demangle_component. */
|
||||||
|
|
||||||
|
static struct demangle_component *
|
||||||
|
d_number_component (struct d_info *di)
|
||||||
|
{
|
||||||
|
struct demangle_component *ret = d_make_empty (di);
|
||||||
|
if (ret)
|
||||||
|
{
|
||||||
|
ret->type = DEMANGLE_COMPONENT_NUMBER;
|
||||||
|
ret->u.s_number.number = d_number (di);
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
/* identifier ::= <(unqualified source code identifier)> */
|
/* identifier ::= <(unqualified source code identifier)> */
|
||||||
|
|
||||||
static struct demangle_component *
|
static struct demangle_component *
|
||||||
|
|
@ -2200,6 +2217,10 @@ cplus_demangle_type (struct d_info *di)
|
||||||
ret->u.s_fixed.sat = (peek == 's');
|
ret->u.s_fixed.sat = (peek == 's');
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case 'v':
|
||||||
|
ret = d_vector_type (di);
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
@ -2418,6 +2439,34 @@ d_array_type (struct d_info *di)
|
||||||
cplus_demangle_type (di));
|
cplus_demangle_type (di));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* <vector-type> ::= Dv <number> _ <type>
|
||||||
|
::= Dv _ <expression> _ <type> */
|
||||||
|
|
||||||
|
static struct demangle_component *
|
||||||
|
d_vector_type (struct d_info *di)
|
||||||
|
{
|
||||||
|
char peek;
|
||||||
|
struct demangle_component *dim;
|
||||||
|
|
||||||
|
peek = d_peek_char (di);
|
||||||
|
if (peek == '_')
|
||||||
|
{
|
||||||
|
d_advance (di, 1);
|
||||||
|
dim = d_expression (di);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
dim = d_number_component (di);
|
||||||
|
|
||||||
|
if (dim == NULL)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
if (! d_check_char (di, '_'))
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
return d_make_comp (di, DEMANGLE_COMPONENT_VECTOR_TYPE, dim,
|
||||||
|
cplus_demangle_type (di));
|
||||||
|
}
|
||||||
|
|
||||||
/* <pointer-to-member-type> ::= M <(class) type> <(member) type> */
|
/* <pointer-to-member-type> ::= M <(class) type> <(member) type> */
|
||||||
|
|
||||||
static struct demangle_component *
|
static struct demangle_component *
|
||||||
|
|
@ -3930,6 +3979,7 @@ d_print_comp (struct d_print_info *dpi,
|
||||||
}
|
}
|
||||||
|
|
||||||
case DEMANGLE_COMPONENT_PTRMEM_TYPE:
|
case DEMANGLE_COMPONENT_PTRMEM_TYPE:
|
||||||
|
case DEMANGLE_COMPONENT_VECTOR_TYPE:
|
||||||
{
|
{
|
||||||
struct d_print_mod dpm;
|
struct d_print_mod dpm;
|
||||||
|
|
||||||
|
|
@ -3944,11 +3994,7 @@ d_print_comp (struct d_print_info *dpi,
|
||||||
/* If the modifier didn't get printed by the type, print it
|
/* If the modifier didn't get printed by the type, print it
|
||||||
now. */
|
now. */
|
||||||
if (! dpm.printed)
|
if (! dpm.printed)
|
||||||
{
|
d_print_mod (dpi, dc);
|
||||||
d_append_char (dpi, ' ');
|
|
||||||
d_print_comp (dpi, d_left (dc));
|
|
||||||
d_append_string (dpi, "::*");
|
|
||||||
}
|
|
||||||
|
|
||||||
dpi->modifiers = dpm.next;
|
dpi->modifiers = dpm.next;
|
||||||
|
|
||||||
|
|
@ -4168,6 +4214,10 @@ d_print_comp (struct d_print_info *dpi,
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
case DEMANGLE_COMPONENT_NUMBER:
|
||||||
|
d_append_num (dpi, dc->u.s_number.number);
|
||||||
|
return;
|
||||||
|
|
||||||
case DEMANGLE_COMPONENT_JAVA_RESOURCE:
|
case DEMANGLE_COMPONENT_JAVA_RESOURCE:
|
||||||
d_append_string (dpi, "java resource ");
|
d_append_string (dpi, "java resource ");
|
||||||
d_print_comp (dpi, d_left (dc));
|
d_print_comp (dpi, d_left (dc));
|
||||||
|
|
@ -4440,6 +4490,12 @@ d_print_mod (struct d_print_info *dpi,
|
||||||
case DEMANGLE_COMPONENT_TYPED_NAME:
|
case DEMANGLE_COMPONENT_TYPED_NAME:
|
||||||
d_print_comp (dpi, d_left (mod));
|
d_print_comp (dpi, d_left (mod));
|
||||||
return;
|
return;
|
||||||
|
case DEMANGLE_COMPONENT_VECTOR_TYPE:
|
||||||
|
d_append_string (dpi, " vector[");
|
||||||
|
d_print_comp (dpi, d_left (mod));
|
||||||
|
d_append_char (dpi, ']');
|
||||||
|
return;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
/* Otherwise, we have something that won't go back on the
|
/* Otherwise, we have something that won't go back on the
|
||||||
modifier stack, so we can just print it. */
|
modifier stack, so we can just print it. */
|
||||||
|
|
|
||||||
|
|
@ -3926,6 +3926,12 @@ S<int>::x::{lambda()#3}::operator()() const
|
||||||
--format=gnu-v3
|
--format=gnu-v3
|
||||||
_Z1fN1SUt_E
|
_Z1fN1SUt_E
|
||||||
f(S::{unnamed type#1})
|
f(S::{unnamed type#1})
|
||||||
|
--format=gnu-v3
|
||||||
|
_Z1fDv32_f
|
||||||
|
f(float vector[32])
|
||||||
|
--format=gnu-v3
|
||||||
|
_Z1fIfLi4EEvDv_T0__T_
|
||||||
|
void f<float, 4>(float vector[4])
|
||||||
#
|
#
|
||||||
# Ada (GNAT) tests.
|
# Ada (GNAT) tests.
|
||||||
#
|
#
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue