Index: clang/include/clang/Basic/AArch64SVEACLETypes.def =================================================================== --- clang/include/clang/Basic/AArch64SVEACLETypes.def +++ clang/include/clang/Basic/AArch64SVEACLETypes.def @@ -38,83 +38,84 @@ //===----------------------------------------------------------------------===// #ifndef SVE_VECTOR_TYPE -#define SVE_VECTOR_TYPE(Name, Id, SingletonId, NumEls, ElBits, IsSigned, IsFP) \ +#define SVE_VECTOR_TYPE(Name, MangledName, Id, SingletonId, NumEls, ElBits, \ + IsSigned, IsFP) \ SVE_TYPE(Name, Id, SingletonId) #endif #ifndef SVE_PREDICATE_TYPE -#define SVE_PREDICATE_TYPE(Name, Id, SingletonId, NumEls)\ +#define SVE_PREDICATE_TYPE(Name, MangledName, Id, SingletonId, NumEls) \ SVE_TYPE(Name, Id, SingletonId) #endif //===- Vector point types -----------------------------------------------===// -SVE_VECTOR_TYPE("__SVInt8_t", SveInt8, SveInt8Ty, 16, 8, true, false) -SVE_VECTOR_TYPE("__SVInt16_t", SveInt16, SveInt16Ty, 8, 16, true, false) -SVE_VECTOR_TYPE("__SVInt32_t", SveInt32, SveInt32Ty, 4, 32, true, false) -SVE_VECTOR_TYPE("__SVInt64_t", SveInt64, SveInt64Ty, 2, 64, true, false) +SVE_VECTOR_TYPE("__SVInt8_t", "__SVInt8_t", SveInt8, SveInt8Ty, 16, 8, true, false) +SVE_VECTOR_TYPE("__SVInt16_t", "__SVInt16_t", SveInt16, SveInt16Ty, 8, 16, true, false) +SVE_VECTOR_TYPE("__SVInt32_t", "__SVInt32_t", SveInt32, SveInt32Ty, 4, 32, true, false) +SVE_VECTOR_TYPE("__SVInt64_t", "__SVInt64_t", SveInt64, SveInt64Ty, 2, 64, true, false) -SVE_VECTOR_TYPE("__SVUint8_t", SveUint8, SveUint8Ty, 16, 8, false, false) -SVE_VECTOR_TYPE("__SVUint16_t", SveUint16, SveUint16Ty, 8, 16, false, false) -SVE_VECTOR_TYPE("__SVUint32_t", SveUint32, SveUint32Ty, 4, 32, false, false) -SVE_VECTOR_TYPE("__SVUint64_t", SveUint64, SveUint64Ty, 2, 64, false, false) +SVE_VECTOR_TYPE("__SVUint8_t", "__SVUint8_t", SveUint8, SveUint8Ty, 16, 8, false, false) +SVE_VECTOR_TYPE("__SVUint16_t", "__SVUint16_t", SveUint16, SveUint16Ty, 8, 16, false, false) +SVE_VECTOR_TYPE("__SVUint32_t", "__SVUint32_t", SveUint32, SveUint32Ty, 4, 32, false, false) +SVE_VECTOR_TYPE("__SVUint64_t", "__SVUint64_t", SveUint64, SveUint64Ty, 2, 64, false, false) -SVE_VECTOR_TYPE("__SVFloat16_t", SveFloat16, SveFloat16Ty, 8, 16, true, true) -SVE_VECTOR_TYPE("__SVFloat32_t", SveFloat32, SveFloat32Ty, 4, 32, true, true) -SVE_VECTOR_TYPE("__SVFloat64_t", SveFloat64, SveFloat64Ty, 2, 64, true, true) +SVE_VECTOR_TYPE("__SVFloat16_t", "__SVFloat16_t", SveFloat16, SveFloat16Ty, 8, 16, true, true) +SVE_VECTOR_TYPE("__SVFloat32_t", "__SVFloat32_t", SveFloat32, SveFloat32Ty, 4, 32, true, true) +SVE_VECTOR_TYPE("__SVFloat64_t", "__SVFloat64_t", SveFloat64, SveFloat64Ty, 2, 64, true, true) // // x2 // -SVE_VECTOR_TYPE("__SVInt8x2_t", SveInt8x2, SveInt8x2Ty, 32, 8, true, false) -SVE_VECTOR_TYPE("__SVInt16x2_t", SveInt16x2, SveInt16x2Ty, 16, 16, true, false) -SVE_VECTOR_TYPE("__SVInt32x2_t", SveInt32x2, SveInt32x2Ty, 8, 32, true, false) -SVE_VECTOR_TYPE("__SVInt64x2_t", SveInt64x2, SveInt64x2Ty, 4, 64, true, false) +SVE_VECTOR_TYPE("__clang_svint8x2_t", "svint8x2_t", SveInt8x2, SveInt8x2Ty, 32, 8, true, false) +SVE_VECTOR_TYPE("__clang_svint16x2_t", "svint16x2_t", SveInt16x2, SveInt16x2Ty, 16, 16, true, false) +SVE_VECTOR_TYPE("__clang_svint32x2_t", "svint32x2_t", SveInt32x2, SveInt32x2Ty, 8, 32, true, false) +SVE_VECTOR_TYPE("__clang_svint64x2_t", "svint64x2_t", SveInt64x2, SveInt64x2Ty, 4, 64, true, false) -SVE_VECTOR_TYPE("__SVUint8x2_t", SveUint8x2, SveUint8x2Ty, 32, 8, false, false) -SVE_VECTOR_TYPE("__SVUint16x2_t", SveUint16x2, SveUint16x2Ty, 16, 16, false, false) -SVE_VECTOR_TYPE("__SVUint32x2_t", SveUint32x2, SveUint32x2Ty, 8, 32, false, false) -SVE_VECTOR_TYPE("__SVUint64x2_t", SveUint64x2, SveUint64x2Ty, 4, 64, false, false) +SVE_VECTOR_TYPE("__clang_svuint8x2_t", "svuint8x2_t", SveUint8x2, SveUint8x2Ty, 32, 8, false, false) +SVE_VECTOR_TYPE("__clang_svuint16x2_t", "svuint16x2_t", SveUint16x2, SveUint16x2Ty, 16, 16, false, false) +SVE_VECTOR_TYPE("__clang_svuint32x2_t", "svuint32x2_t", SveUint32x2, SveUint32x2Ty, 8, 32, false, false) +SVE_VECTOR_TYPE("__clang_svuint64x2_t", "svuint64x2_t", SveUint64x2, SveUint64x2Ty, 4, 64, false, false) -SVE_VECTOR_TYPE("__SVFloat16x2_t", SveFloat16x2, SveFloat16x2Ty, 16, 16, true, true) -SVE_VECTOR_TYPE("__SVFloat32x2_t", SveFloat32x2, SveFloat32x2Ty, 8, 32, true, true) -SVE_VECTOR_TYPE("__SVFloat64x2_t", SveFloat64x2, SveFloat64x2Ty, 4, 64, true, true) +SVE_VECTOR_TYPE("__clang_svfloat16x2_t", "svfloat16x2_t", SveFloat16x2, SveFloat16x2Ty, 16, 16, true, true) +SVE_VECTOR_TYPE("__clang_svfloat32x2_t", "svfloat32x2_t", SveFloat32x2, SveFloat32x2Ty, 8, 32, true, true) +SVE_VECTOR_TYPE("__clang_svfloat64x2_t", "svfloat64x2_t", SveFloat64x2, SveFloat64x2Ty, 4, 64, true, true) // // x3 // -SVE_VECTOR_TYPE("__SVInt8x3_t", SveInt8x3, SveInt8x3Ty, 48, 8, true, false) -SVE_VECTOR_TYPE("__SVInt16x3_t", SveInt16x3, SveInt16x3Ty, 24, 16, true, false) -SVE_VECTOR_TYPE("__SVInt32x3_t", SveInt32x3, SveInt32x3Ty, 12, 32, true, false) -SVE_VECTOR_TYPE("__SVInt64x3_t", SveInt64x3, SveInt64x3Ty, 6, 64, true, false) +SVE_VECTOR_TYPE("__clang_svint8x3_t", "svint8x3_t", SveInt8x3, SveInt8x3Ty, 48, 8, true, false) +SVE_VECTOR_TYPE("__clang_svint16x3_t", "svint16x3_t", SveInt16x3, SveInt16x3Ty, 24, 16, true, false) +SVE_VECTOR_TYPE("__clang_svint32x3_t", "svint32x3_t", SveInt32x3, SveInt32x3Ty, 12, 32, true, false) +SVE_VECTOR_TYPE("__clang_svint64x3_t", "svint64x3_t", SveInt64x3, SveInt64x3Ty, 6, 64, true, false) -SVE_VECTOR_TYPE("__SVUint8x3_t", SveUint8x3, SveUint8x3Ty, 48, 8, false, false) -SVE_VECTOR_TYPE("__SVUint16x3_t", SveUint16x3, SveUint16x3Ty, 24, 16, false, false) -SVE_VECTOR_TYPE("__SVUint32x3_t", SveUint32x3, SveUint32x3Ty, 12, 32, false, false) -SVE_VECTOR_TYPE("__SVUint64x3_t", SveUint64x3, SveUint64x3Ty, 6, 64, false, false) +SVE_VECTOR_TYPE("__clang_svuint8x3_t", "svuint8x3_t", SveUint8x3, SveUint8x3Ty, 48, 8, false, false) +SVE_VECTOR_TYPE("__clang_svuint16x3_t", "svuint16x3_t", SveUint16x3, SveUint16x3Ty, 24, 16, false, false) +SVE_VECTOR_TYPE("__clang_svuint32x3_t", "svuint32x3_t", SveUint32x3, SveUint32x3Ty, 12, 32, false, false) +SVE_VECTOR_TYPE("__clang_svuint64x3_t", "svuint64x3_t", SveUint64x3, SveUint64x3Ty, 6, 64, false, false) -SVE_VECTOR_TYPE("__SVFloat16x3_t", SveFloat16x3, SveFloat16x3Ty, 24, 16, true, true) -SVE_VECTOR_TYPE("__SVFloat32x3_t", SveFloat32x3, SveFloat32x3Ty, 12, 32, true, true) -SVE_VECTOR_TYPE("__SVFloat64x3_t", SveFloat64x3, SveFloat64x3Ty, 6, 64, true, true) +SVE_VECTOR_TYPE("__clang_svfloat16x3_t", "svfloat16x3_t", SveFloat16x3, SveFloat16x3Ty, 24, 16, true, true) +SVE_VECTOR_TYPE("__clang_svfloat32x3_t", "svfloat32x3_t", SveFloat32x3, SveFloat32x3Ty, 12, 32, true, true) +SVE_VECTOR_TYPE("__clang_svfloat64x3_t", "svfloat64x3_t", SveFloat64x3, SveFloat64x3Ty, 6, 64, true, true) // // x4 // -SVE_VECTOR_TYPE("__SVInt8x4_t", SveInt8x4, SveInt8x4Ty, 64, 8, true, false) -SVE_VECTOR_TYPE("__SVInt16x4_t", SveInt16x4, SveInt16x4Ty, 32, 16, true, false) -SVE_VECTOR_TYPE("__SVInt32x4_t", SveInt32x4, SveInt32x4Ty, 16, 32, true, false) -SVE_VECTOR_TYPE("__SVInt64x4_t", SveInt64x4, SveInt64x4Ty, 8, 64, true, false) +SVE_VECTOR_TYPE("__clang_svint8x4_t", "svint8x4_t", SveInt8x4, SveInt8x4Ty, 64, 8, true, false) +SVE_VECTOR_TYPE("__clang_svint16x4_t", "svint16x4_t", SveInt16x4, SveInt16x4Ty, 32, 16, true, false) +SVE_VECTOR_TYPE("__clang_svint32x4_t", "svint32x4_t", SveInt32x4, SveInt32x4Ty, 16, 32, true, false) +SVE_VECTOR_TYPE("__clang_svint64x4_t", "svint64x4_t", SveInt64x4, SveInt64x4Ty, 8, 64, true, false) -SVE_VECTOR_TYPE("__SVUint8x4_t", SveUint8x4, SveUint8x4Ty, 64, 8, false, false) -SVE_VECTOR_TYPE("__SVUint16x4_t", SveUint16x4, SveUint16x4Ty, 32, 16, false, false) -SVE_VECTOR_TYPE("__SVUint32x4_t", SveUint32x4, SveUint32x4Ty, 16, 32, false, false) -SVE_VECTOR_TYPE("__SVUint64x4_t", SveUint64x4, SveUint64x4Ty, 8, 64, false, false) +SVE_VECTOR_TYPE("__clang_svuint8x4_t", "svuint8x4_t", SveUint8x4, SveUint8x4Ty, 64, 8, false, false) +SVE_VECTOR_TYPE("__clang_svuint16x4_t", "svuint16x4_t", SveUint16x4, SveUint16x4Ty, 32, 16, false, false) +SVE_VECTOR_TYPE("__clang_svuint32x4_t", "svuint32x4_t", SveUint32x4, SveUint32x4Ty, 16, 32, false, false) +SVE_VECTOR_TYPE("__clang_svuint64x4_t", "svuint64x4_t", SveUint64x4, SveUint64x4Ty, 8, 64, false, false) -SVE_VECTOR_TYPE("__SVFloat16x4_t", SveFloat16x4, SveFloat16x4Ty, 32, 16, true, true) -SVE_VECTOR_TYPE("__SVFloat32x4_t", SveFloat32x4, SveFloat32x4Ty, 16, 32, true, true) -SVE_VECTOR_TYPE("__SVFloat64x4_t", SveFloat64x4, SveFloat64x4Ty, 8, 64, true, true) +SVE_VECTOR_TYPE("__clang_svfloat16x4_t", "svfloat16x4_t", SveFloat16x4, SveFloat16x4Ty, 32, 16, true, true) +SVE_VECTOR_TYPE("__clang_svfloat32x4_t", "svfloat32x4_t", SveFloat32x4, SveFloat32x4Ty, 16, 32, true, true) +SVE_VECTOR_TYPE("__clang_svfloat64x4_t", "svfloat64x4_t", SveFloat64x4, SveFloat64x4Ty, 8, 64, true, true) -SVE_PREDICATE_TYPE("__SVBool_t", SveBool, SveBoolTy, 16) +SVE_PREDICATE_TYPE("__SVBool_t", "__SVBool_t", SveBool, SveBoolTy, 16) #undef SVE_VECTOR_TYPE #undef SVE_PREDICATE_TYPE Index: clang/lib/AST/ASTContext.cpp =================================================================== --- clang/lib/AST/ASTContext.cpp +++ clang/lib/AST/ASTContext.cpp @@ -2131,12 +2131,13 @@ // Because the length is only known at runtime, we use a dummy value // of 0 for the static length. The alignment values are those defined // by the Procedure Call Standard for the Arm Architecture. -#define SVE_VECTOR_TYPE(Name, Id, SingletonId, NumEls, ElBits, IsSigned, IsFP) \ +#define SVE_VECTOR_TYPE(Name, MangledName, Id, SingletonId, NumEls, ElBits, \ + IsSigned, IsFP) \ case BuiltinType::Id: \ Width = 0; \ Align = 128; \ break; -#define SVE_PREDICATE_TYPE(Name, Id, SingletonId, NumEls) \ +#define SVE_PREDICATE_TYPE(Name, MangledName, Id, SingletonId, NumEls) \ case BuiltinType::Id: \ Width = 0; \ Align = 16; \ @@ -3640,14 +3641,15 @@ unsigned NumElts) const { if (Target->hasAArch64SVETypes()) { uint64_t EltTySize = getTypeSize(EltTy); -#define SVE_VECTOR_TYPE(Name, Id, SingletonId, NumEls, ElBits, IsSigned, IsFP) \ +#define SVE_VECTOR_TYPE(Name, MangledName, Id, SingletonId, NumEls, ElBits, \ + IsSigned, IsFP) \ if (!EltTy->isBooleanType() && \ ((EltTy->hasIntegerRepresentation() && \ EltTy->hasSignedIntegerRepresentation() == IsSigned) || \ (EltTy->hasFloatingRepresentation() && IsFP)) && \ EltTySize == ElBits && NumElts == NumEls) \ return SingletonId; -#define SVE_PREDICATE_TYPE(Name, Id, SingletonId, NumEls) \ +#define SVE_PREDICATE_TYPE(Name, MangledName, Id, SingletonId, NumEls) \ if (EltTy->isBooleanType() && NumElts == NumEls) \ return SingletonId; #include "clang/Basic/AArch64SVEACLETypes.def" Index: clang/lib/AST/ItaniumMangle.cpp =================================================================== --- clang/lib/AST/ItaniumMangle.cpp +++ clang/lib/AST/ItaniumMangle.cpp @@ -2820,10 +2820,18 @@ // The SVE types are effectively target-specific. The mangling scheme // is defined in the appendices to the Procedure Call Standard for the // Arm Architecture. -#define SVE_TYPE(Name, Id, SingletonId) \ - case BuiltinType::Id: \ - type_name = Name; \ - Out << 'u' << type_name.size() << type_name; \ +#define SVE_VECTOR_TYPE(InternalName, MangledName, Id, SingletonId, NumEls, \ + ElBits, IsSigned, IsFP) \ + case BuiltinType::Id: \ + type_name = MangledName; \ + Out << (type_name == InternalName ? "u" : "") << type_name.size() \ + << type_name; \ + break; +#define SVE_PREDICATE_TYPE(InternalName, MangledName, Id, SingletonId, NumEls) \ + case BuiltinType::Id: \ + type_name = MangledName; \ + Out << (type_name == InternalName ? "u" : "") << type_name.size() \ + << type_name; \ break; #include "clang/Basic/AArch64SVEACLETypes.def" } Index: clang/test/CodeGenCXX/aarch64-mangle-sve-vectors.cpp =================================================================== --- clang/test/CodeGenCXX/aarch64-mangle-sve-vectors.cpp +++ clang/test/CodeGenCXX/aarch64-mangle-sve-vectors.cpp @@ -29,3 +29,72 @@ void f11(S<__SVFloat64_t>) {} // CHECK: _Z3f121SIu10__SVBool_tE void f12(S<__SVBool_t>) {} + +// The tuple types don't use the internal name for mangling. + +// CHECK: _Z3f131SI10svint8x2_tE +void f13(S<__clang_svint8x2_t>) {} +// CHECK: _Z3f141SI10svint8x3_tE +void f14(S<__clang_svint8x3_t>) {} +// CHECK: _Z3f151SI10svint8x4_tE +void f15(S<__clang_svint8x4_t>) {} +// CHECK: _Z3f161SI11svint16x2_tE +void f16(S<__clang_svint16x2_t>) {} +// CHECK: _Z3f171SI11svint16x3_tE +void f17(S<__clang_svint16x3_t>) {} +// CHECK: _Z3f181SI11svint16x4_tE +void f18(S<__clang_svint16x4_t>) {} +// CHECK: _Z3f191SI11svint32x2_tE +void f19(S<__clang_svint32x2_t>) {} +// CHECK: _Z3f201SI11svint32x3_tE +void f20(S<__clang_svint32x3_t>) {} +// CHECK: _Z3f211SI11svint32x4_tE +void f21(S<__clang_svint32x4_t>) {} +// CHECK: _Z3f221SI11svint64x2_tE +void f22(S<__clang_svint64x2_t>) {} +// CHECK: _Z3f231SI11svint64x3_tE +void f23(S<__clang_svint64x3_t>) {} +// CHECK: _Z3f241SI11svint64x4_tE +void f24(S<__clang_svint64x4_t>) {} +// CHECK: _Z3f251SI11svuint8x2_tE +void f25(S<__clang_svuint8x2_t>) {} +// CHECK: _Z3f261SI11svuint8x3_tE +void f26(S<__clang_svuint8x3_t>) {} +// CHECK: _Z3f271SI11svuint8x4_tE +void f27(S<__clang_svuint8x4_t>) {} +// CHECK: _Z3f281SI12svuint16x2_tE +void f28(S<__clang_svuint16x2_t>) {} +// CHECK: _Z3f291SI12svuint16x3_tE +void f29(S<__clang_svuint16x3_t>) {} +// CHECK: _Z3f301SI12svuint16x4_tE +void f30(S<__clang_svuint16x4_t>) {} +// CHECK: _Z3f311SI12svuint32x2_tE +void f31(S<__clang_svuint32x2_t>) {} +// CHECK: _Z3f321SI12svuint32x3_tE +void f32(S<__clang_svuint32x3_t>) {} +// CHECK: _Z3f331SI12svuint32x4_tE +void f33(S<__clang_svuint32x4_t>) {} +// CHECK: _Z3f341SI12svuint64x2_tE +void f34(S<__clang_svuint64x2_t>) {} +// CHECK: _Z3f351SI12svuint64x3_tE +void f35(S<__clang_svuint64x3_t>) {} +// CHECK: _Z3f361SI12svuint64x4_tE +void f36(S<__clang_svuint64x4_t>) {} +// CHECK: _Z3f371SI13svfloat16x2_tE +void f37(S<__clang_svfloat16x2_t>) {} +// CHECK: _Z3f381SI13svfloat16x3_tE +void f38(S<__clang_svfloat16x3_t>) {} +// CHECK: _Z3f391SI13svfloat16x4_tE +void f39(S<__clang_svfloat16x4_t>) {} +// CHECK: _Z3f401SI13svfloat32x2_tE +void f40(S<__clang_svfloat32x2_t>) {} +// CHECK: _Z3f411SI13svfloat32x3_tE +void f41(S<__clang_svfloat32x3_t>) {} +// CHECK: _Z3f421SI13svfloat32x4_tE +void f42(S<__clang_svfloat32x4_t>) {} +// CHECK: _Z3f431SI13svfloat64x2_tE +void f43(S<__clang_svfloat64x2_t>) {} +// CHECK: _Z3f441SI13svfloat64x3_tE +void f44(S<__clang_svfloat64x3_t>) {} +// CHECK: _Z3f451SI13svfloat64x4_tE +void f45(S<__clang_svfloat64x4_t>) {} Index: clang/utils/TableGen/SveEmitter.cpp =================================================================== --- clang/utils/TableGen/SveEmitter.cpp +++ clang/utils/TableGen/SveEmitter.cpp @@ -1069,39 +1069,39 @@ OS << "typedef __SVFloat16_t svfloat16_t;\n"; OS << "typedef __SVFloat32_t svfloat32_t;\n"; OS << "typedef __SVFloat64_t svfloat64_t;\n"; - OS << "typedef __SVInt8x2_t svint8x2_t;\n"; - OS << "typedef __SVInt16x2_t svint16x2_t;\n"; - OS << "typedef __SVInt32x2_t svint32x2_t;\n"; - OS << "typedef __SVInt64x2_t svint64x2_t;\n"; - OS << "typedef __SVUint8x2_t svuint8x2_t;\n"; - OS << "typedef __SVUint16x2_t svuint16x2_t;\n"; - OS << "typedef __SVUint32x2_t svuint32x2_t;\n"; - OS << "typedef __SVUint64x2_t svuint64x2_t;\n"; - OS << "typedef __SVFloat16x2_t svfloat16x2_t;\n"; - OS << "typedef __SVFloat32x2_t svfloat32x2_t;\n"; - OS << "typedef __SVFloat64x2_t svfloat64x2_t;\n"; - OS << "typedef __SVInt8x3_t svint8x3_t;\n"; - OS << "typedef __SVInt16x3_t svint16x3_t;\n"; - OS << "typedef __SVInt32x3_t svint32x3_t;\n"; - OS << "typedef __SVInt64x3_t svint64x3_t;\n"; - OS << "typedef __SVUint8x3_t svuint8x3_t;\n"; - OS << "typedef __SVUint16x3_t svuint16x3_t;\n"; - OS << "typedef __SVUint32x3_t svuint32x3_t;\n"; - OS << "typedef __SVUint64x3_t svuint64x3_t;\n"; - OS << "typedef __SVFloat16x3_t svfloat16x3_t;\n"; - OS << "typedef __SVFloat32x3_t svfloat32x3_t;\n"; - OS << "typedef __SVFloat64x3_t svfloat64x3_t;\n"; - OS << "typedef __SVInt8x4_t svint8x4_t;\n"; - OS << "typedef __SVInt16x4_t svint16x4_t;\n"; - OS << "typedef __SVInt32x4_t svint32x4_t;\n"; - OS << "typedef __SVInt64x4_t svint64x4_t;\n"; - OS << "typedef __SVUint8x4_t svuint8x4_t;\n"; - OS << "typedef __SVUint16x4_t svuint16x4_t;\n"; - OS << "typedef __SVUint32x4_t svuint32x4_t;\n"; - OS << "typedef __SVUint64x4_t svuint64x4_t;\n"; - OS << "typedef __SVFloat16x4_t svfloat16x4_t;\n"; - OS << "typedef __SVFloat32x4_t svfloat32x4_t;\n"; - OS << "typedef __SVFloat64x4_t svfloat64x4_t;\n"; + OS << "typedef __clang_svint8x2_t svint8x2_t;\n"; + OS << "typedef __clang_svint16x2_t svint16x2_t;\n"; + OS << "typedef __clang_svint32x2_t svint32x2_t;\n"; + OS << "typedef __clang_svint64x2_t svint64x2_t;\n"; + OS << "typedef __clang_svuint8x2_t svuint8x2_t;\n"; + OS << "typedef __clang_svuint16x2_t svuint16x2_t;\n"; + OS << "typedef __clang_svuint32x2_t svuint32x2_t;\n"; + OS << "typedef __clang_svuint64x2_t svuint64x2_t;\n"; + OS << "typedef __clang_svfloat16x2_t svfloat16x2_t;\n"; + OS << "typedef __clang_svfloat32x2_t svfloat32x2_t;\n"; + OS << "typedef __clang_svfloat64x2_t svfloat64x2_t;\n"; + OS << "typedef __clang_svint8x3_t svint8x3_t;\n"; + OS << "typedef __clang_svint16x3_t svint16x3_t;\n"; + OS << "typedef __clang_svint32x3_t svint32x3_t;\n"; + OS << "typedef __clang_svint64x3_t svint64x3_t;\n"; + OS << "typedef __clang_svuint8x3_t svuint8x3_t;\n"; + OS << "typedef __clang_svuint16x3_t svuint16x3_t;\n"; + OS << "typedef __clang_svuint32x3_t svuint32x3_t;\n"; + OS << "typedef __clang_svuint64x3_t svuint64x3_t;\n"; + OS << "typedef __clang_svfloat16x3_t svfloat16x3_t;\n"; + OS << "typedef __clang_svfloat32x3_t svfloat32x3_t;\n"; + OS << "typedef __clang_svfloat64x3_t svfloat64x3_t;\n"; + OS << "typedef __clang_svint8x4_t svint8x4_t;\n"; + OS << "typedef __clang_svint16x4_t svint16x4_t;\n"; + OS << "typedef __clang_svint32x4_t svint32x4_t;\n"; + OS << "typedef __clang_svint64x4_t svint64x4_t;\n"; + OS << "typedef __clang_svuint8x4_t svuint8x4_t;\n"; + OS << "typedef __clang_svuint16x4_t svuint16x4_t;\n"; + OS << "typedef __clang_svuint32x4_t svuint32x4_t;\n"; + OS << "typedef __clang_svuint64x4_t svuint64x4_t;\n"; + OS << "typedef __clang_svfloat16x4_t svfloat16x4_t;\n"; + OS << "typedef __clang_svfloat32x4_t svfloat32x4_t;\n"; + OS << "typedef __clang_svfloat64x4_t svfloat64x4_t;\n"; OS << "typedef __SVBool_t svbool_t;\n\n"; OS << "typedef enum\n";