From f47e7e4a3480707f124db9622001d3a05a777d5d Mon Sep 17 00:00:00 2001 From: David Truby Date: Mon, 7 Mar 2022 15:09:46 +0000 Subject: [PATCH] [clang][SVE] Add support for bitwise operators on SVE types This patch implements support for the &, |, ^, and ~ operators on sizeless SVE types. Differential Revision: https://reviews.llvm.org/D121119 --- clang/include/clang/Sema/Sema.h | 3 +- clang/lib/AST/Type.cpp | 10 +- clang/lib/Sema/SemaExpr.cpp | 28 +- ...r-ops.c => aarch64-sve-vector-arith-ops.c} | 0 .../CodeGen/aarch64-sve-vector-bitwise-ops.c | 340 +++++++++++++++ ...r-ops.c => aarch64-sve-vector-arith-ops.c} | 0 .../Sema/aarch64-sve-vector-bitwise-ops.c | 394 ++++++++++++++++++ clang/test/Sema/attr-arm-sve-vector-bits.c | 8 +- clang/test/Sema/sizeless-1.c | 7 - clang/test/SemaCXX/sizeless-1.cpp | 7 - 10 files changed, 770 insertions(+), 27 deletions(-) rename clang/test/CodeGen/{aarch64-sve-vector-ops.c => aarch64-sve-vector-arith-ops.c} (100%) create mode 100644 clang/test/CodeGen/aarch64-sve-vector-bitwise-ops.c rename clang/test/Sema/{aarch64-sve-vector-ops.c => aarch64-sve-vector-arith-ops.c} (100%) create mode 100644 clang/test/Sema/aarch64-sve-vector-bitwise-ops.c diff --git a/clang/include/clang/Sema/Sema.h b/clang/include/clang/Sema/Sema.h index fe8a1f371fe7..32a8ffdc8df9 100644 --- a/clang/include/clang/Sema/Sema.h +++ b/clang/include/clang/Sema/Sema.h @@ -11948,7 +11948,8 @@ public: // type checking for sizeless vector binary operators. QualType CheckSizelessVectorOperands(ExprResult &LHS, ExprResult &RHS, - SourceLocation Loc); + SourceLocation Loc, + ArithConvKind OperationKind); /// Type checking for matrix binary operators. QualType CheckMatrixElementwiseOperands(ExprResult &LHS, ExprResult &RHS, diff --git a/clang/lib/AST/Type.cpp b/clang/lib/AST/Type.cpp index 08a95669ac9f..1803fe12d69c 100644 --- a/clang/lib/AST/Type.cpp +++ b/clang/lib/AST/Type.cpp @@ -1899,8 +1899,14 @@ bool Type::hasAutoForTrailingReturnType() const { bool Type::hasIntegerRepresentation() const { if (const auto *VT = dyn_cast(CanonicalType)) return VT->getElementType()->isIntegerType(); - else - return isIntegerType(); + if (CanonicalType->isVLSTBuiltinType()) { + const auto *VT = cast(CanonicalType); + return VT->getKind() == BuiltinType::SveBool || + (VT->getKind() >= BuiltinType::SveInt8 && + VT->getKind() <= BuiltinType::SveUint64); + } + + return isIntegerType(); } /// Determine whether this type is an integral type. diff --git a/clang/lib/Sema/SemaExpr.cpp b/clang/lib/Sema/SemaExpr.cpp index 635721b4cc3b..be90c58e066d 100644 --- a/clang/lib/Sema/SemaExpr.cpp +++ b/clang/lib/Sema/SemaExpr.cpp @@ -10464,7 +10464,8 @@ QualType Sema::CheckVectorOperands(ExprResult &LHS, ExprResult &RHS, } QualType Sema::CheckSizelessVectorOperands(ExprResult &LHS, ExprResult &RHS, - SourceLocation Loc) { + SourceLocation Loc, + ArithConvKind OperationKind) { QualType LHSType = LHS.get()->getType().getUnqualifiedType(); QualType RHSType = RHS.get()->getType().getUnqualifiedType(); @@ -10472,7 +10473,8 @@ QualType Sema::CheckSizelessVectorOperands(ExprResult &LHS, ExprResult &RHS, const BuiltinType *RHSVecType = RHSType->getAs(); unsigned DiagID = diag::err_typecheck_invalid_operands; - if (LHSVecType->isSVEBool() || RHSVecType->isSVEBool()) { + if ((OperationKind == ACK_Arithmetic) && + (LHSVecType->isSVEBool() || RHSVecType->isSVEBool())) { Diag(Loc, DiagID) << LHSType << RHSType << LHS.get()->getSourceRange() << RHS.get()->getSourceRange(); return QualType(); @@ -10600,7 +10602,7 @@ QualType Sema::CheckMultiplyDivideOperands(ExprResult &LHS, ExprResult &RHS, /*AllowBooleanOperation*/ false, /*ReportInvalid*/ true); if (LHSTy->isVLSTBuiltinType() || RHSTy->isVLSTBuiltinType()) - return CheckSizelessVectorOperands(LHS, RHS, Loc); + return CheckSizelessVectorOperands(LHS, RHS, Loc, ACK_Arithmetic); if (!IsDiv && (LHSTy->isConstantMatrixType() || RHSTy->isConstantMatrixType())) return CheckMatrixMultiplyOperands(LHS, RHS, Loc, IsCompAssign); @@ -10650,7 +10652,7 @@ QualType Sema::CheckRemainderOperands( ->getType() ->getSveEltType(Context) ->hasIntegerRepresentation()) - return CheckSizelessVectorOperands(LHS, RHS, Loc); + return CheckSizelessVectorOperands(LHS, RHS, Loc, ACK_Arithmetic); return InvalidOperands(Loc, LHS, RHS); } @@ -10964,7 +10966,8 @@ QualType Sema::CheckAdditionOperands(ExprResult &LHS, ExprResult &RHS, if (LHS.get()->getType()->isVLSTBuiltinType() || RHS.get()->getType()->isVLSTBuiltinType()) { - QualType compType = CheckSizelessVectorOperands(LHS, RHS, Loc); + QualType compType = + CheckSizelessVectorOperands(LHS, RHS, Loc, ACK_Arithmetic); if (CompLHSTy) *CompLHSTy = compType; return compType; @@ -11078,7 +11081,8 @@ QualType Sema::CheckSubtractionOperands(ExprResult &LHS, ExprResult &RHS, if (LHS.get()->getType()->isVLSTBuiltinType() || RHS.get()->getType()->isVLSTBuiltinType()) { - QualType compType = CheckSizelessVectorOperands(LHS, RHS, Loc); + QualType compType = + CheckSizelessVectorOperands(LHS, RHS, Loc, ACK_Arithmetic); if (CompLHSTy) *CompLHSTy = compType; return compType; @@ -11417,6 +11421,10 @@ QualType Sema::CheckShiftOperands(ExprResult &LHS, ExprResult &RHS, return checkVectorShift(*this, LHS, RHS, Loc, IsCompAssign); } + if (LHS.get()->getType()->isVLSTBuiltinType() || + RHS.get()->getType()->isVLSTBuiltinType()) + return InvalidOperands(Loc, LHS, RHS); + // Shifts don't perform usual arithmetic conversions, they just do integer // promotions on each operand. C99 6.5.7p3 @@ -12885,6 +12893,14 @@ inline QualType Sema::CheckBitwiseOperands(ExprResult &LHS, ExprResult &RHS, return InvalidOperands(Loc, LHS, RHS); } + if (LHS.get()->getType()->isVLSTBuiltinType() || + RHS.get()->getType()->isVLSTBuiltinType()) { + if (LHS.get()->getType()->hasIntegerRepresentation() && + RHS.get()->getType()->hasIntegerRepresentation()) + return CheckSizelessVectorOperands(LHS, RHS, Loc, ACK_BitwiseOp); + return InvalidOperands(Loc, LHS, RHS); + } + if (Opc == BO_And) diagnoseLogicalNotOnLHSofCheck(*this, LHS, RHS, Loc, Opc); diff --git a/clang/test/CodeGen/aarch64-sve-vector-ops.c b/clang/test/CodeGen/aarch64-sve-vector-arith-ops.c similarity index 100% rename from clang/test/CodeGen/aarch64-sve-vector-ops.c rename to clang/test/CodeGen/aarch64-sve-vector-arith-ops.c diff --git a/clang/test/CodeGen/aarch64-sve-vector-bitwise-ops.c b/clang/test/CodeGen/aarch64-sve-vector-bitwise-ops.c new file mode 100644 index 000000000000..996f92ebb8fb --- /dev/null +++ b/clang/test/CodeGen/aarch64-sve-vector-bitwise-ops.c @@ -0,0 +1,340 @@ +// NOTE: Assertions have been autogenerated by utils/update_cc_test_checks.py +// RUN: %clang_cc1 -triple aarch64-none-linux-gnu -target-feature +sve \ +// RUN: -fallow-half-arguments-and-returns -disable-O0-optnone \ +// RUN: -emit-llvm -o - %s | opt -S -sroa | FileCheck %s + +// REQUIRES: aarch64-registered-target + +#include + +// AND + +// CHECK-LABEL: @and_bool( +// CHECK-NEXT: entry: +// CHECK-NEXT: [[AND:%.*]] = and [[A:%.*]], [[B:%.*]] +// CHECK-NEXT: ret [[AND]] +// +svbool_t and_bool(svbool_t a, svbool_t b) { + return a & b; +} + +// CHECK-LABEL: @and_i8( +// CHECK-NEXT: entry: +// CHECK-NEXT: [[AND:%.*]] = and [[A:%.*]], [[B:%.*]] +// CHECK-NEXT: ret [[AND]] +// +svint8_t and_i8(svint8_t a, svint8_t b) { + return a & b; +} + +// CHECK-LABEL: @and_i16( +// CHECK-NEXT: entry: +// CHECK-NEXT: [[AND:%.*]] = and [[A:%.*]], [[B:%.*]] +// CHECK-NEXT: ret [[AND]] +// +svint16_t and_i16(svint16_t a, svint16_t b) { + return a & b; +} + +// CHECK-LABEL: @and_i32( +// CHECK-NEXT: entry: +// CHECK-NEXT: [[AND:%.*]] = and [[A:%.*]], [[B:%.*]] +// CHECK-NEXT: ret [[AND]] +// +svint32_t and_i32(svint32_t a, svint32_t b) { + return a & b; +} + +// CHECK-LABEL: @and_i64( +// CHECK-NEXT: entry: +// CHECK-NEXT: [[AND:%.*]] = and [[A:%.*]], [[B:%.*]] +// CHECK-NEXT: ret [[AND]] +// +svint64_t and_i64(svint64_t a, svint64_t b) { + return a & b; +} + +// CHECK-LABEL: @and_u8( +// CHECK-NEXT: entry: +// CHECK-NEXT: [[AND:%.*]] = and [[A:%.*]], [[B:%.*]] +// CHECK-NEXT: ret [[AND]] +// +svuint8_t and_u8(svuint8_t a, svuint8_t b) { + return a & b; +} + +// CHECK-LABEL: @and_u16( +// CHECK-NEXT: entry: +// CHECK-NEXT: [[AND:%.*]] = and [[A:%.*]], [[B:%.*]] +// CHECK-NEXT: ret [[AND]] +// +svuint16_t and_u16(svuint16_t a, svuint16_t b) { + return a & b; +} + +// CHECK-LABEL: @and_u32( +// CHECK-NEXT: entry: +// CHECK-NEXT: [[AND:%.*]] = and [[A:%.*]], [[B:%.*]] +// CHECK-NEXT: ret [[AND]] +// +svuint32_t and_u32(svuint32_t a, svuint32_t b) { + return a & b; +} + +// CHECK-LABEL: @and_u64( +// CHECK-NEXT: entry: +// CHECK-NEXT: [[AND:%.*]] = and [[A:%.*]], [[B:%.*]] +// CHECK-NEXT: ret [[AND]] +// +svuint64_t and_u64(svuint64_t a, svuint64_t b) { + return a & b; +} + +// OR + +// CHECK-LABEL: @or_bool( +// CHECK-NEXT: entry: +// CHECK-NEXT: [[OR:%.*]] = or [[A:%.*]], [[B:%.*]] +// CHECK-NEXT: ret [[OR]] +// +svbool_t or_bool(svbool_t a, svbool_t b) { + return a | b; +} + +// CHECK-LABEL: @or_i8( +// CHECK-NEXT: entry: +// CHECK-NEXT: [[OR:%.*]] = or [[A:%.*]], [[B:%.*]] +// CHECK-NEXT: ret [[OR]] +// +svint8_t or_i8(svint8_t a, svint8_t b) { + return a | b; +} + +// CHECK-LABEL: @or_i16( +// CHECK-NEXT: entry: +// CHECK-NEXT: [[OR:%.*]] = or [[A:%.*]], [[B:%.*]] +// CHECK-NEXT: ret [[OR]] +// +svint16_t or_i16(svint16_t a, svint16_t b) { + return a | b; +} + +// CHECK-LABEL: @or_i32( +// CHECK-NEXT: entry: +// CHECK-NEXT: [[OR:%.*]] = or [[A:%.*]], [[B:%.*]] +// CHECK-NEXT: ret [[OR]] +// +svint32_t or_i32(svint32_t a, svint32_t b) { + return a | b; +} + +// CHECK-LABEL: @or_i64( +// CHECK-NEXT: entry: +// CHECK-NEXT: [[OR:%.*]] = or [[A:%.*]], [[B:%.*]] +// CHECK-NEXT: ret [[OR]] +// +svint64_t or_i64(svint64_t a, svint64_t b) { + return a | b; +} + +// CHECK-LABEL: @or_u8( +// CHECK-NEXT: entry: +// CHECK-NEXT: [[OR:%.*]] = or [[A:%.*]], [[B:%.*]] +// CHECK-NEXT: ret [[OR]] +// +svuint8_t or_u8(svuint8_t a, svuint8_t b) { + return a | b; +} + +// CHECK-LABEL: @or_u16( +// CHECK-NEXT: entry: +// CHECK-NEXT: [[OR:%.*]] = or [[A:%.*]], [[B:%.*]] +// CHECK-NEXT: ret [[OR]] +// +svuint16_t or_u16(svuint16_t a, svuint16_t b) { + return a | b; +} + +// CHECK-LABEL: @or_u32( +// CHECK-NEXT: entry: +// CHECK-NEXT: [[OR:%.*]] = or [[A:%.*]], [[B:%.*]] +// CHECK-NEXT: ret [[OR]] +// +svuint32_t or_u32(svuint32_t a, svuint32_t b) { + return a | b; +} + +// CHECK-LABEL: @or_u64( +// CHECK-NEXT: entry: +// CHECK-NEXT: [[OR:%.*]] = or [[A:%.*]], [[B:%.*]] +// CHECK-NEXT: ret [[OR]] +// +svuint64_t or_u64(svuint64_t a, svuint64_t b) { + return a | b; +} + +// XOR + +// CHECK-LABEL: @xor_bool( +// CHECK-NEXT: entry: +// CHECK-NEXT: [[XOR:%.*]] = xor [[A:%.*]], [[B:%.*]] +// CHECK-NEXT: ret [[XOR]] +// +svbool_t xor_bool(svbool_t a, svbool_t b) { + return a ^ b; +} + +// CHECK-LABEL: @xor_i8( +// CHECK-NEXT: entry: +// CHECK-NEXT: [[XOR:%.*]] = xor [[A:%.*]], [[B:%.*]] +// CHECK-NEXT: ret [[XOR]] +// +svint8_t xor_i8(svint8_t a, svint8_t b) { + return a ^ b; +} + +// CHECK-LABEL: @xor_i16( +// CHECK-NEXT: entry: +// CHECK-NEXT: [[XOR:%.*]] = xor [[A:%.*]], [[B:%.*]] +// CHECK-NEXT: ret [[XOR]] +// +svint16_t xor_i16(svint16_t a, svint16_t b) { + return a ^ b; +} + +// CHECK-LABEL: @xor_i32( +// CHECK-NEXT: entry: +// CHECK-NEXT: [[XOR:%.*]] = xor [[A:%.*]], [[B:%.*]] +// CHECK-NEXT: ret [[XOR]] +// +svint32_t xor_i32(svint32_t a, svint32_t b) { + return a ^ b; +} + +// CHECK-LABEL: @xor_i64( +// CHECK-NEXT: entry: +// CHECK-NEXT: [[XOR:%.*]] = xor [[A:%.*]], [[B:%.*]] +// CHECK-NEXT: ret [[XOR]] +// +svint64_t xor_i64(svint64_t a, svint64_t b) { + return a ^ b; +} + +// CHECK-LABEL: @xor_u8( +// CHECK-NEXT: entry: +// CHECK-NEXT: [[XOR:%.*]] = xor [[A:%.*]], [[B:%.*]] +// CHECK-NEXT: ret [[XOR]] +// +svuint8_t xor_u8(svuint8_t a, svuint8_t b) { + return a ^ b; +} + +// CHECK-LABEL: @xor_u16( +// CHECK-NEXT: entry: +// CHECK-NEXT: [[XOR:%.*]] = xor [[A:%.*]], [[B:%.*]] +// CHECK-NEXT: ret [[XOR]] +// +svuint16_t xor_u16(svuint16_t a, svuint16_t b) { + return a ^ b; +} + +// CHECK-LABEL: @xor_u32( +// CHECK-NEXT: entry: +// CHECK-NEXT: [[XOR:%.*]] = xor [[A:%.*]], [[B:%.*]] +// CHECK-NEXT: ret [[XOR]] +// +svuint32_t xor_u32(svuint32_t a, svuint32_t b) { + return a ^ b; +} + +// CHECK-LABEL: @xor_u64( +// CHECK-NEXT: entry: +// CHECK-NEXT: [[XOR:%.*]] = xor [[A:%.*]], [[B:%.*]] +// CHECK-NEXT: ret [[XOR]] +// +svuint64_t xor_u64(svuint64_t a, svuint64_t b) { + return a ^ b; +} + +// NEG + +// CHECK-LABEL: @neg_bool( +// CHECK-NEXT: entry: +// CHECK-NEXT: [[NEG:%.*]] = xor [[A:%.*]], shufflevector ( insertelement ( poison, i1 true, i32 0), poison, zeroinitializer) +// CHECK-NEXT: ret [[NEG]] +// +svbool_t neg_bool(svbool_t a) { + return ~a; +} + +// CHECK-LABEL: @neg_i8( +// CHECK-NEXT: entry: +// CHECK-NEXT: [[NEG:%.*]] = xor [[A:%.*]], shufflevector ( insertelement ( poison, i8 -1, i32 0), poison, zeroinitializer) +// CHECK-NEXT: ret [[NEG]] +// +svint8_t neg_i8(svint8_t a) { + return ~a; +} + +// CHECK-LABEL: @neg_i16( +// CHECK-NEXT: entry: +// CHECK-NEXT: [[NEG:%.*]] = xor [[A:%.*]], shufflevector ( insertelement ( poison, i16 -1, i32 0), poison, zeroinitializer) +// CHECK-NEXT: ret [[NEG]] +// +svint16_t neg_i16(svint16_t a) { + return ~a; +} + +// CHECK-LABEL: @neg_i32( +// CHECK-NEXT: entry: +// CHECK-NEXT: [[NEG:%.*]] = xor [[A:%.*]], shufflevector ( insertelement ( poison, i32 -1, i32 0), poison, zeroinitializer) +// CHECK-NEXT: ret [[NEG]] +// +svint32_t neg_i32(svint32_t a) { + return ~a; +} + +// CHECK-LABEL: @neg_i64( +// CHECK-NEXT: entry: +// CHECK-NEXT: [[NEG:%.*]] = xor [[A:%.*]], shufflevector ( insertelement ( poison, i64 -1, i32 0), poison, zeroinitializer) +// CHECK-NEXT: ret [[NEG]] +// +svint64_t neg_i64(svint64_t a) { + return ~a; +} + +// CHECK-LABEL: @neg_u8( +// CHECK-NEXT: entry: +// CHECK-NEXT: [[NEG:%.*]] = xor [[A:%.*]], shufflevector ( insertelement ( poison, i8 -1, i32 0), poison, zeroinitializer) +// CHECK-NEXT: ret [[NEG]] +// +svuint8_t neg_u8(svuint8_t a) { + return ~a; +} + +// CHECK-LABEL: @neg_u16( +// CHECK-NEXT: entry: +// CHECK-NEXT: [[NEG:%.*]] = xor [[A:%.*]], shufflevector ( insertelement ( poison, i16 -1, i32 0), poison, zeroinitializer) +// CHECK-NEXT: ret [[NEG]] +// +svuint16_t neg_u16(svuint16_t a) { + return ~a; +} + +// CHECK-LABEL: @neg_u32( +// CHECK-NEXT: entry: +// CHECK-NEXT: [[NEG:%.*]] = xor [[A:%.*]], shufflevector ( insertelement ( poison, i32 -1, i32 0), poison, zeroinitializer) +// CHECK-NEXT: ret [[NEG]] +// +svuint32_t neg_u32(svuint32_t a) { + return ~a; +} + +// CHECK-LABEL: @neg_u64( +// CHECK-NEXT: entry: +// CHECK-NEXT: [[NEG:%.*]] = xor [[A:%.*]], shufflevector ( insertelement ( poison, i64 -1, i32 0), poison, zeroinitializer) +// CHECK-NEXT: ret [[NEG]] +// +svuint64_t neg_u64(svuint64_t a) { + return ~a; +} diff --git a/clang/test/Sema/aarch64-sve-vector-ops.c b/clang/test/Sema/aarch64-sve-vector-arith-ops.c similarity index 100% rename from clang/test/Sema/aarch64-sve-vector-ops.c rename to clang/test/Sema/aarch64-sve-vector-arith-ops.c diff --git a/clang/test/Sema/aarch64-sve-vector-bitwise-ops.c b/clang/test/Sema/aarch64-sve-vector-bitwise-ops.c new file mode 100644 index 000000000000..d1afd116a775 --- /dev/null +++ b/clang/test/Sema/aarch64-sve-vector-bitwise-ops.c @@ -0,0 +1,394 @@ +// RUN: %clang_cc1 -verify -triple aarch64-none-linux-gnu -target-feature +sve -fallow-half-arguments-and-returns -fsyntax-only %s + +// REQUIRES: aarch64-registered-target + +#include + +void and (svint8_t i8, svint16_t i16, svint32_t i32, svint64_t i64, + svuint8_t u8, svuint16_t u16, svuint32_t u32, svuint64_t u64, + svfloat16_t f16, svfloat32_t f32, svfloat64_t f64, + svbool_t b) { + (void)(i8 & b); // expected-error{{invalid operands to binary expression}} + (void)(i8 & i16); // expected-error{{invalid operands to binary expression}} + (void)(i8 & i32); // expected-error{{invalid operands to binary expression}} + (void)(i8 & i64); // expected-error{{invalid operands to binary expression}} + (void)(i8 & u16); // expected-error{{invalid operands to binary expression}} + (void)(i8 & u32); // expected-error{{invalid operands to binary expression}} + (void)(i8 & u64); // expected-error{{invalid operands to binary expression}} + (void)(i8 & f16); // expected-error{{invalid operands to binary expression}} + (void)(i8 & f32); // expected-error{{invalid operands to binary expression}} + (void)(i8 & f64); // expected-error{{invalid operands to binary expression}} + + (void)(u8 & b); // expected-error{{invalid operands to binary expression}} + (void)(u8 & i16); // expected-error{{invalid operands to binary expression}} + (void)(u8 & i32); // expected-error{{invalid operands to binary expression}} + (void)(u8 & i64); // expected-error{{invalid operands to binary expression}} + (void)(u8 & u16); // expected-error{{invalid operands to binary expression}} + (void)(u8 & u32); // expected-error{{invalid operands to binary expression}} + (void)(u8 & u64); // expected-error{{invalid operands to binary expression}} + (void)(u8 & f16); // expected-error{{invalid operands to binary expression}} + (void)(u8 & f32); // expected-error{{invalid operands to binary expression}} + (void)(u8 & f64); // expected-error{{invalid operands to binary expression}} + + (void)(i16 & b); // expected-error{{invalid operands to binary expression}} + (void)(i16 & i8); // expected-error{{invalid operands to binary expression}} + (void)(i16 & i32); // expected-error{{invalid operands to binary expression}} + (void)(i16 & i64); // expected-error{{invalid operands to binary expression}} + (void)(i16 & u8); // expected-error{{invalid operands to binary expression}} + (void)(i16 & u32); // expected-error{{invalid operands to binary expression}} + (void)(i16 & u64); // expected-error{{invalid operands to binary expression}} + (void)(i16 & f16); // expected-error{{invalid operands to binary expression}} + (void)(i16 & f32); // expected-error{{invalid operands to binary expression}} + (void)(i16 & f64); // expected-error{{invalid operands to binary expression}} + + (void)(u16 & b); // expected-error{{invalid operands to binary expression}} + (void)(u16 & i8); // expected-error{{invalid operands to binary expression}} + (void)(u16 & i32); // expected-error{{invalid operands to binary expression}} + (void)(u16 & i64); // expected-error{{invalid operands to binary expression}} + (void)(u16 & u8); // expected-error{{invalid operands to binary expression}} + (void)(u16 & u32); // expected-error{{invalid operands to binary expression}} + (void)(u16 & u64); // expected-error{{invalid operands to binary expression}} + (void)(u16 & f16); // expected-error{{invalid operands to binary expression}} + (void)(u16 & f32); // expected-error{{invalid operands to binary expression}} + (void)(u16 & f64); // expected-error{{invalid operands to binary expression}} + + (void)(i32 & b); // expected-error{{invalid operands to binary expression}} + (void)(i32 & i8); // expected-error{{invalid operands to binary expression}} + (void)(i32 & i16); // expected-error{{invalid operands to binary expression}} + (void)(i32 & i64); // expected-error{{invalid operands to binary expression}} + (void)(i32 & u8); // expected-error{{invalid operands to binary expression}} + (void)(i32 & u16); // expected-error{{invalid operands to binary expression}} + (void)(i32 & u64); // expected-error{{invalid operands to binary expression}} + (void)(i32 & f16); // expected-error{{invalid operands to binary expression}} + (void)(i32 & f32); // expected-error{{invalid operands to binary expression}} + (void)(i32 & f64); // expected-error{{invalid operands to binary expression}} + + (void)(u32 & b); // expected-error{{invalid operands to binary expression}} + (void)(u32 & i8); // expected-error{{invalid operands to binary expression}} + (void)(u32 & i16); // expected-error{{invalid operands to binary expression}} + (void)(u32 & i64); // expected-error{{invalid operands to binary expression}} + (void)(u32 & u8); // expected-error{{invalid operands to binary expression}} + (void)(u32 & u16); // expected-error{{invalid operands to binary expression}} + (void)(u32 & u64); // expected-error{{invalid operands to binary expression}} + (void)(u32 & f16); // expected-error{{invalid operands to binary expression}} + (void)(u32 & f32); // expected-error{{invalid operands to binary expression}} + (void)(u32 & f64); // expected-error{{invalid operands to binary expression}} + + (void)(i64 & b); // expected-error{{invalid operands to binary expression}} + (void)(i64 & i8); // expected-error{{invalid operands to binary expression}} + (void)(i64 & i16); // expected-error{{invalid operands to binary expression}} + (void)(i64 & i32); // expected-error{{invalid operands to binary expression}} + (void)(i64 & u8); // expected-error{{invalid operands to binary expression}} + (void)(i64 & u16); // expected-error{{invalid operands to binary expression}} + (void)(i64 & u32); // expected-error{{invalid operands to binary expression}} + (void)(i64 & f16); // expected-error{{invalid operands to binary expression}} + (void)(i64 & f32); // expected-error{{invalid operands to binary expression}} + (void)(i64 & f64); // expected-error{{invalid operands to binary expression}} + + (void)(u64 & b); // expected-error{{invalid operands to binary expression}} + (void)(u64 & i8); // expected-error{{invalid operands to binary expression}} + (void)(u64 & i16); // expected-error{{invalid operands to binary expression}} + (void)(u64 & i32); // expected-error{{invalid operands to binary expression}} + (void)(u64 & u8); // expected-error{{invalid operands to binary expression}} + (void)(u64 & u16); // expected-error{{invalid operands to binary expression}} + (void)(u64 & u32); // expected-error{{invalid operands to binary expression}} + (void)(u64 & f16); // expected-error{{invalid operands to binary expression}} + (void)(u64 & f32); // expected-error{{invalid operands to binary expression}} + (void)(u64 & f64); // expected-error{{invalid operands to binary expression}} + + (void)(f16 & b); // expected-error{{invalid operands to binary expression}} + (void)(f16 & i8); // expected-error{{invalid operands to binary expression}} + (void)(f16 & i16); // expected-error{{invalid operands to binary expression}} + (void)(f16 & i32); // expected-error{{invalid operands to binary expression}} + (void)(f16 & i64); // expected-error{{invalid operands to binary expression}} + (void)(f16 & u8); // expected-error{{invalid operands to binary expression}} + (void)(f16 & u32); // expected-error{{invalid operands to binary expression}} + (void)(f16 & u64); // expected-error{{invalid operands to binary expression}} + (void)(f16 & f32); // expected-error{{invalid operands to binary expression}} + (void)(f16 & f64); // expected-error{{invalid operands to binary expression}} + + (void)(f32 & b); // expected-error{{invalid operands to binary expression}} + (void)(f32 & i8); // expected-error{{invalid operands to binary expression}} + (void)(f32 & i16); // expected-error{{invalid operands to binary expression}} + (void)(f32 & i32); // expected-error{{invalid operands to binary expression}} + (void)(f32 & i64); // expected-error{{invalid operands to binary expression}} + (void)(f32 & u8); // expected-error{{invalid operands to binary expression}} + (void)(f32 & u16); // expected-error{{invalid operands to binary expression}} + (void)(f32 & u64); // expected-error{{invalid operands to binary expression}} + (void)(f32 & f16); // expected-error{{invalid operands to binary expression}} + (void)(f32 & f32); // expected-error{{invalid operands to binary expression}} + (void)(f32 & f64); // expected-error{{invalid operands to binary expression}} + + (void)(f64 & b); // expected-error{{invalid operands to binary expression}} + (void)(f64 & i8); // expected-error{{invalid operands to binary expression}} + (void)(f64 & i16); // expected-error{{invalid operands to binary expression}} + (void)(f64 & i32); // expected-error{{invalid operands to binary expression}} + (void)(f64 & i64); // expected-error{{invalid operands to binary expression}} + (void)(f64 & u8); // expected-error{{invalid operands to binary expression}} + (void)(f64 & u16); // expected-error{{invalid operands to binary expression}} + (void)(f64 & u32); // expected-error{{invalid operands to binary expression}} + (void)(f64 & f16); // expected-error{{invalid operands to binary expression}} + (void)(f64 & f32); // expected-error{{invalid operands to binary expression}} + (void)(f64 & f64); // expected-error{{invalid operands to binary expression}} +} + +void or (svint8_t i8, svint16_t i16, svint32_t i32, svint64_t i64, + svuint8_t u8, svuint16_t u16, svuint32_t u32, svuint64_t u64, + svfloat16_t f16, svfloat32_t f32, svfloat64_t f64, + svbool_t b) { + (void)(i8 | b); // expected-error{{invalid operands to binary expression}} + (void)(i8 | i16); // expected-error{{invalid operands to binary expression}} + (void)(i8 | i32); // expected-error{{invalid operands to binary expression}} + (void)(i8 | i64); // expected-error{{invalid operands to binary expression}} + (void)(i8 | u16); // expected-error{{invalid operands to binary expression}} + (void)(i8 | u32); // expected-error{{invalid operands to binary expression}} + (void)(i8 | u64); // expected-error{{invalid operands to binary expression}} + (void)(i8 | f16); // expected-error{{invalid operands to binary expression}} + (void)(i8 | f32); // expected-error{{invalid operands to binary expression}} + (void)(i8 | f64); // expected-error{{invalid operands to binary expression}} + + (void)(u8 | b); // expected-error{{invalid operands to binary expression}} + (void)(u8 | i16); // expected-error{{invalid operands to binary expression}} + (void)(u8 | i32); // expected-error{{invalid operands to binary expression}} + (void)(u8 | i64); // expected-error{{invalid operands to binary expression}} + (void)(u8 | u16); // expected-error{{invalid operands to binary expression}} + (void)(u8 | u32); // expected-error{{invalid operands to binary expression}} + (void)(u8 | u64); // expected-error{{invalid operands to binary expression}} + (void)(u8 | f16); // expected-error{{invalid operands to binary expression}} + (void)(u8 | f32); // expected-error{{invalid operands to binary expression}} + (void)(u8 | f64); // expected-error{{invalid operands to binary expression}} + + (void)(i16 | b); // expected-error{{invalid operands to binary expression}} + (void)(i16 | i8); // expected-error{{invalid operands to binary expression}} + (void)(i16 | i32); // expected-error{{invalid operands to binary expression}} + (void)(i16 | i64); // expected-error{{invalid operands to binary expression}} + (void)(i16 | u8); // expected-error{{invalid operands to binary expression}} + (void)(i16 | u32); // expected-error{{invalid operands to binary expression}} + (void)(i16 | u64); // expected-error{{invalid operands to binary expression}} + (void)(i16 | f16); // expected-error{{invalid operands to binary expression}} + (void)(i16 | f32); // expected-error{{invalid operands to binary expression}} + (void)(i16 | f64); // expected-error{{invalid operands to binary expression}} + + (void)(u16 | b); // expected-error{{invalid operands to binary expression}} + (void)(u16 | i8); // expected-error{{invalid operands to binary expression}} + (void)(u16 | i32); // expected-error{{invalid operands to binary expression}} + (void)(u16 | i64); // expected-error{{invalid operands to binary expression}} + (void)(u16 | u8); // expected-error{{invalid operands to binary expression}} + (void)(u16 | u32); // expected-error{{invalid operands to binary expression}} + (void)(u16 | u64); // expected-error{{invalid operands to binary expression}} + (void)(u16 | f16); // expected-error{{invalid operands to binary expression}} + (void)(u16 | f32); // expected-error{{invalid operands to binary expression}} + (void)(u16 | f64); // expected-error{{invalid operands to binary expression}} + + (void)(i32 | b); // expected-error{{invalid operands to binary expression}} + (void)(i32 | i8); // expected-error{{invalid operands to binary expression}} + (void)(i32 | i16); // expected-error{{invalid operands to binary expression}} + (void)(i32 | i64); // expected-error{{invalid operands to binary expression}} + (void)(i32 | u8); // expected-error{{invalid operands to binary expression}} + (void)(i32 | u16); // expected-error{{invalid operands to binary expression}} + (void)(i32 | u64); // expected-error{{invalid operands to binary expression}} + (void)(i32 | f16); // expected-error{{invalid operands to binary expression}} + (void)(i32 | f32); // expected-error{{invalid operands to binary expression}} + (void)(i32 | f64); // expected-error{{invalid operands to binary expression}} + + (void)(u32 | b); // expected-error{{invalid operands to binary expression}} + (void)(u32 | i8); // expected-error{{invalid operands to binary expression}} + (void)(u32 | i16); // expected-error{{invalid operands to binary expression}} + (void)(u32 | i64); // expected-error{{invalid operands to binary expression}} + (void)(u32 | u8); // expected-error{{invalid operands to binary expression}} + (void)(u32 | u16); // expected-error{{invalid operands to binary expression}} + (void)(u32 | u64); // expected-error{{invalid operands to binary expression}} + (void)(u32 | f16); // expected-error{{invalid operands to binary expression}} + (void)(u32 | f32); // expected-error{{invalid operands to binary expression}} + (void)(u32 | f64); // expected-error{{invalid operands to binary expression}} + + (void)(i64 | b); // expected-error{{invalid operands to binary expression}} + (void)(i64 | i8); // expected-error{{invalid operands to binary expression}} + (void)(i64 | i16); // expected-error{{invalid operands to binary expression}} + (void)(i64 | i32); // expected-error{{invalid operands to binary expression}} + (void)(i64 | u8); // expected-error{{invalid operands to binary expression}} + (void)(i64 | u16); // expected-error{{invalid operands to binary expression}} + (void)(i64 | u32); // expected-error{{invalid operands to binary expression}} + (void)(i64 | f16); // expected-error{{invalid operands to binary expression}} + (void)(i64 | f32); // expected-error{{invalid operands to binary expression}} + (void)(i64 | f64); // expected-error{{invalid operands to binary expression}} + + (void)(u64 | b); // expected-error{{invalid operands to binary expression}} + (void)(u64 | i8); // expected-error{{invalid operands to binary expression}} + (void)(u64 | i16); // expected-error{{invalid operands to binary expression}} + (void)(u64 | i32); // expected-error{{invalid operands to binary expression}} + (void)(u64 | u8); // expected-error{{invalid operands to binary expression}} + (void)(u64 | u16); // expected-error{{invalid operands to binary expression}} + (void)(u64 | u32); // expected-error{{invalid operands to binary expression}} + (void)(u64 | f16); // expected-error{{invalid operands to binary expression}} + (void)(u64 | f32); // expected-error{{invalid operands to binary expression}} + (void)(u64 | f64); // expected-error{{invalid operands to binary expression}} + + (void)(f16 | b); // expected-error{{invalid operands to binary expression}} + (void)(f16 | i8); // expected-error{{invalid operands to binary expression}} + (void)(f16 | i16); // expected-error{{invalid operands to binary expression}} + (void)(f16 | i32); // expected-error{{invalid operands to binary expression}} + (void)(f16 | i64); // expected-error{{invalid operands to binary expression}} + (void)(f16 | u8); // expected-error{{invalid operands to binary expression}} + (void)(f16 | u32); // expected-error{{invalid operands to binary expression}} + (void)(f16 | u64); // expected-error{{invalid operands to binary expression}} + (void)(f16 | f16); // expected-error{{invalid operands to binary expression}} + (void)(f16 | f32); // expected-error{{invalid operands to binary expression}} + (void)(f16 | f64); // expected-error{{invalid operands to binary expression}} + + (void)(f32 | b); // expected-error{{invalid operands to binary expression}} + (void)(f32 | i8); // expected-error{{invalid operands to binary expression}} + (void)(f32 | i16); // expected-error{{invalid operands to binary expression}} + (void)(f32 | i32); // expected-error{{invalid operands to binary expression}} + (void)(f32 | i64); // expected-error{{invalid operands to binary expression}} + (void)(f32 | u8); // expected-error{{invalid operands to binary expression}} + (void)(f32 | u16); // expected-error{{invalid operands to binary expression}} + (void)(f32 | u64); // expected-error{{invalid operands to binary expression}} + (void)(f32 | f16); // expected-error{{invalid operands to binary expression}} + (void)(f32 | f32); // expected-error{{invalid operands to binary expression}} + (void)(f32 | f64); // expected-error{{invalid operands to binary expression}} + + (void)(f64 | b); // expected-error{{invalid operands to binary expression}} + (void)(f64 | i8); // expected-error{{invalid operands to binary expression}} + (void)(f64 | i16); // expected-error{{invalid operands to binary expression}} + (void)(f64 | i32); // expected-error{{invalid operands to binary expression}} + (void)(f64 | i64); // expected-error{{invalid operands to binary expression}} + (void)(f64 | u8); // expected-error{{invalid operands to binary expression}} + (void)(f64 | u16); // expected-error{{invalid operands to binary expression}} + (void)(f64 | u32); // expected-error{{invalid operands to binary expression}} + (void)(f64 | f16); // expected-error{{invalid operands to binary expression}} + (void)(f64 | f32); // expected-error{{invalid operands to binary expression}} + (void)(f64 | f64); // expected-error{{invalid operands to binary expression}} +} + +void xor (svint8_t i8, svint16_t i16, svint32_t i32, svint64_t i64, svuint8_t u8, svuint16_t u16, svuint32_t u32, svuint64_t u64, svfloat16_t f16, svfloat32_t f32, svfloat64_t f64, svbool_t b) { + (void)(i8 ^ b); // expected-error{{invalid operands to binary expression}} + (void)(i8 ^ i16); // expected-error{{invalid operands to binary expression}} + (void)(i8 ^ i32); // expected-error{{invalid operands to binary expression}} + (void)(i8 ^ i64); // expected-error{{invalid operands to binary expression}} + (void)(i8 ^ u16); // expected-error{{invalid operands to binary expression}} + (void)(i8 ^ u32); // expected-error{{invalid operands to binary expression}} + (void)(i8 ^ u64); // expected-error{{invalid operands to binary expression}} + (void)(i8 ^ f16); // expected-error{{invalid operands to binary expression}} + (void)(i8 ^ f32); // expected-error{{invalid operands to binary expression}} + (void)(i8 ^ f64); // expected-error{{invalid operands to binary expression}} + + (void)(u8 ^ b); // expected-error{{invalid operands to binary expression}} + (void)(u8 ^ i16); // expected-error{{invalid operands to binary expression}} + (void)(u8 ^ i32); // expected-error{{invalid operands to binary expression}} + (void)(u8 ^ i64); // expected-error{{invalid operands to binary expression}} + (void)(u8 ^ u16); // expected-error{{invalid operands to binary expression}} + (void)(u8 ^ u32); // expected-error{{invalid operands to binary expression}} + (void)(u8 ^ u64); // expected-error{{invalid operands to binary expression}} + (void)(u8 ^ f16); // expected-error{{invalid operands to binary expression}} + (void)(u8 ^ f32); // expected-error{{invalid operands to binary expression}} + (void)(u8 ^ f64); // expected-error{{invalid operands to binary expression}} + + (void)(i16 ^ b); // expected-error{{invalid operands to binary expression}} + (void)(i16 ^ i8); // expected-error{{invalid operands to binary expression}} + (void)(i16 ^ i32); // expected-error{{invalid operands to binary expression}} + (void)(i16 ^ i64); // expected-error{{invalid operands to binary expression}} + (void)(i16 ^ u8); // expected-error{{invalid operands to binary expression}} + (void)(i16 ^ u32); // expected-error{{invalid operands to binary expression}} + (void)(i16 ^ u64); // expected-error{{invalid operands to binary expression}} + (void)(i16 ^ f16); // expected-error{{invalid operands to binary expression}} + (void)(i16 ^ f32); // expected-error{{invalid operands to binary expression}} + (void)(i16 ^ f64); // expected-error{{invalid operands to binary expression}} + + (void)(u16 ^ b); // expected-error{{invalid operands to binary expression}} + (void)(u16 ^ i8); // expected-error{{invalid operands to binary expression}} + (void)(u16 ^ i32); // expected-error{{invalid operands to binary expression}} + (void)(u16 ^ i64); // expected-error{{invalid operands to binary expression}} + (void)(u16 ^ u8); // expected-error{{invalid operands to binary expression}} + (void)(u16 ^ u32); // expected-error{{invalid operands to binary expression}} + (void)(u16 ^ u64); // expected-error{{invalid operands to binary expression}} + (void)(u16 ^ f16); // expected-error{{invalid operands to binary expression}} + (void)(u16 ^ f32); // expected-error{{invalid operands to binary expression}} + (void)(u16 ^ f64); // expected-error{{invalid operands to binary expression}} + + (void)(i32 ^ b); // expected-error{{invalid operands to binary expression}} + (void)(i32 ^ i8); // expected-error{{invalid operands to binary expression}} + (void)(i32 ^ i16); // expected-error{{invalid operands to binary expression}} + (void)(i32 ^ i64); // expected-error{{invalid operands to binary expression}} + (void)(i32 ^ u8); // expected-error{{invalid operands to binary expression}} + (void)(i32 ^ u16); // expected-error{{invalid operands to binary expression}} + (void)(i32 ^ u64); // expected-error{{invalid operands to binary expression}} + (void)(i32 ^ f16); // expected-error{{invalid operands to binary expression}} + (void)(i32 ^ f32); // expected-error{{invalid operands to binary expression}} + (void)(i32 ^ f64); // expected-error{{invalid operands to binary expression}} + + (void)(u32 ^ b); // expected-error{{invalid operands to binary expression}} + (void)(u32 ^ i8); // expected-error{{invalid operands to binary expression}} + (void)(u32 ^ i16); // expected-error{{invalid operands to binary expression}} + (void)(u32 ^ i64); // expected-error{{invalid operands to binary expression}} + (void)(u32 ^ u8); // expected-error{{invalid operands to binary expression}} + (void)(u32 ^ u16); // expected-error{{invalid operands to binary expression}} + (void)(u32 ^ u64); // expected-error{{invalid operands to binary expression}} + (void)(u32 ^ f16); // expected-error{{invalid operands to binary expression}} + (void)(u32 ^ f32); // expected-error{{invalid operands to binary expression}} + (void)(u32 ^ f64); // expected-error{{invalid operands to binary expression}} + + (void)(i64 ^ b); // expected-error{{invalid operands to binary expression}} + (void)(i64 ^ i8); // expected-error{{invalid operands to binary expression}} + (void)(i64 ^ i16); // expected-error{{invalid operands to binary expression}} + (void)(i64 ^ i32); // expected-error{{invalid operands to binary expression}} + (void)(i64 ^ u8); // expected-error{{invalid operands to binary expression}} + (void)(i64 ^ u16); // expected-error{{invalid operands to binary expression}} + (void)(i64 ^ u32); // expected-error{{invalid operands to binary expression}} + (void)(i64 ^ f16); // expected-error{{invalid operands to binary expression}} + (void)(i64 ^ f32); // expected-error{{invalid operands to binary expression}} + (void)(i64 ^ f64); // expected-error{{invalid operands to binary expression}} + + (void)(u64 ^ b); // expected-error{{invalid operands to binary expression}} + (void)(u64 ^ i8); // expected-error{{invalid operands to binary expression}} + (void)(u64 ^ i16); // expected-error{{invalid operands to binary expression}} + (void)(u64 ^ i32); // expected-error{{invalid operands to binary expression}} + (void)(u64 ^ u8); // expected-error{{invalid operands to binary expression}} + (void)(u64 ^ u16); // expected-error{{invalid operands to binary expression}} + (void)(u64 ^ u32); // expected-error{{invalid operands to binary expression}} + (void)(u64 ^ f16); // expected-error{{invalid operands to binary expression}} + (void)(u64 ^ f32); // expected-error{{invalid operands to binary expression}} + (void)(u64 ^ f64); // expected-error{{invalid operands to binary expression}} + + (void)(f16 ^ b); // expected-error{{invalid operands to binary expression}} + (void)(f16 ^ i8); // expected-error{{invalid operands to binary expression}} + (void)(f16 ^ i16); // expected-error{{invalid operands to binary expression}} + (void)(f16 ^ i32); // expected-error{{invalid operands to binary expression}} + (void)(f16 ^ i64); // expected-error{{invalid operands to binary expression}} + (void)(f16 ^ u8); // expected-error{{invalid operands to binary expression}} + (void)(f16 ^ u32); // expected-error{{invalid operands to binary expression}} + (void)(f16 ^ u64); // expected-error{{invalid operands to binary expression}} + (void)(f16 ^ f16); // expected-error{{invalid operands to binary expression}} + (void)(f16 ^ f32); // expected-error{{invalid operands to binary expression}} + (void)(f16 ^ f64); // expected-error{{invalid operands to binary expression}} + + (void)(f32 ^ b); // expected-error{{invalid operands to binary expression}} + (void)(f32 ^ i8); // expected-error{{invalid operands to binary expression}} + (void)(f32 ^ i16); // expected-error{{invalid operands to binary expression}} + (void)(f32 ^ i32); // expected-error{{invalid operands to binary expression}} + (void)(f32 ^ i64); // expected-error{{invalid operands to binary expression}} + (void)(f32 ^ u8); // expected-error{{invalid operands to binary expression}} + (void)(f32 ^ u16); // expected-error{{invalid operands to binary expression}} + (void)(f32 ^ u64); // expected-error{{invalid operands to binary expression}} + (void)(f32 ^ f16); // expected-error{{invalid operands to binary expression}} + (void)(f32 ^ f32); // expected-error{{invalid operands to binary expression}} + (void)(f32 ^ f64); // expected-error{{invalid operands to binary expression}} + + (void)(f64 ^ b); // expected-error{{invalid operands to binary expression}} + (void)(f64 ^ i8); // expected-error{{invalid operands to binary expression}} + (void)(f64 ^ i16); // expected-error{{invalid operands to binary expression}} + (void)(f64 ^ i32); // expected-error{{invalid operands to binary expression}} + (void)(f64 ^ i64); // expected-error{{invalid operands to binary expression}} + (void)(f64 ^ u8); // expected-error{{invalid operands to binary expression}} + (void)(f64 ^ u16); // expected-error{{invalid operands to binary expression}} + (void)(f64 ^ u32); // expected-error{{invalid operands to binary expression}} + (void)(f64 ^ f16); // expected-error{{invalid operands to binary expression}} + (void)(f64 ^ f32); // expected-error{{invalid operands to binary expression}} + (void)(f64 ^ f64); // expected-error{{invalid operands to binary expression}} +} + + void not(svfloat16_t f16, svfloat32_t f32, svfloat32_t f64) { + (void)(~f16); // expected-error{{invalid argument type}} + (void)(~f32); // expected-error{{invalid argument type}} + (void)(~f64); // expected-error{{invalid argument type}} +} diff --git a/clang/test/Sema/attr-arm-sve-vector-bits.c b/clang/test/Sema/attr-arm-sve-vector-bits.c index 8ae65c926899..33d9798707d2 100644 --- a/clang/test/Sema/attr-arm-sve-vector-bits.c +++ b/clang/test/Sema/attr-arm-sve-vector-bits.c @@ -165,13 +165,13 @@ void f(int c) { gs8 = gs8 == ss8; // expected-error {{cannot combine GNU and SVE vectors in expression, result is ambiguous}} gs8 = gs8 == fs8; // expected-error {{cannot combine GNU and SVE vectors in expression, result is ambiguous}} - ss8 = ss8 & fs8; // expected-error {{invalid operands to binary expression}} - ss8 = ss8 & gs8; // expected-error {{invalid operands to binary expression}} + ss8 = ss8 & fs8; // expected-error {{cannot combine fixed-length and sizeless SVE vectors in expression, result is ambiguous}} + ss8 = ss8 & gs8; // expected-error {{cannot combine GNU and SVE vectors in expression, result is ambiguous}} - fs8 = fs8 & ss8; // expected-error {{invalid operands to binary expression}} + fs8 = fs8 & ss8; // expected-error {{cannot combine fixed-length and sizeless SVE vectors in expression, result is ambiguous}} fs8 = fs8 & gs8; // expected-error {{cannot combine GNU and SVE vectors in expression, result is ambiguous}} - gs8 = gs8 & ss8; // expected-error {{invalid operands to binary expression}} + gs8 = gs8 & ss8; // expected-error {{cannot combine GNU and SVE vectors in expression, result is ambiguous}} gs8 = gs8 & fs8; // expected-error {{cannot combine GNU and SVE vectors in expression, result is ambiguous}} } diff --git a/clang/test/Sema/sizeless-1.c b/clang/test/Sema/sizeless-1.c index e7e374d099b4..1bf344e2bf0b 100644 --- a/clang/test/Sema/sizeless-1.c +++ b/clang/test/Sema/sizeless-1.c @@ -193,15 +193,11 @@ void func(int sel) { -init_int8; // expected-error {{invalid argument type 'svint8_t'}} --init_int8; // expected-error {{cannot decrement value of type 'svint8_t'}} init_int8--; // expected-error {{cannot decrement value of type 'svint8_t'}} - ~init_int8; // expected-error {{invalid argument type 'svint8_t'}} !init_int8; // expected-error {{invalid argument type 'svint8_t'}} *init_int8; // expected-error {{indirection requires pointer operand}} __real init_int8; // expected-error {{invalid type 'svint8_t'}} __imag init_int8; // expected-error {{invalid type 'svint8_t'}} - local_int8 &init_int8; // expected-error {{invalid operands to binary expression}} - local_int8 | init_int8; // expected-error {{invalid operands to binary expression}} - local_int8 ^ init_int8; // expected-error {{invalid operands to binary expression}} local_int8 << init_int8; // expected-error {{invalid operands to binary expression}} local_int8 >> init_int8; // expected-error {{invalid operands to binary expression}} local_int8 < init_int8; // expected-error {{invalid operands to binary expression}} @@ -213,9 +209,6 @@ void func(int sel) { local_int8 &&init_int8; // expected-error {{invalid operands to binary expression}} local_int8 || init_int8; // expected-error {{invalid operands to binary expression}} - local_int8 &= init_int8; // expected-error {{invalid operands to binary expression}} - local_int8 |= init_int8; // expected-error {{invalid operands to binary expression}} - local_int8 ^= init_int8; // expected-error {{invalid operands to binary expression}} local_int8 <<= init_int8; // expected-error {{invalid operands to binary expression}} local_int8 >>= init_int8; // expected-error {{invalid operands to binary expression}} diff --git a/clang/test/SemaCXX/sizeless-1.cpp b/clang/test/SemaCXX/sizeless-1.cpp index f4d020b9ab51..d7684c08641d 100644 --- a/clang/test/SemaCXX/sizeless-1.cpp +++ b/clang/test/SemaCXX/sizeless-1.cpp @@ -205,15 +205,11 @@ void func(int sel) { -init_int8; // expected-error {{invalid argument type 'svint8_t'}} --init_int8; // expected-error {{cannot decrement value of type 'svint8_t'}} init_int8--; // expected-error {{cannot decrement value of type 'svint8_t'}} - ~init_int8; // expected-error {{invalid argument type 'svint8_t'}} !init_int8; // expected-error {{invalid argument type 'svint8_t'}} *init_int8; // expected-error {{indirection requires pointer operand}} __real init_int8; // expected-error {{invalid type 'svint8_t'}} __imag init_int8; // expected-error {{invalid type 'svint8_t'}} - local_int8 &init_int8; // expected-error {{invalid operands to binary expression}} - local_int8 | init_int8; // expected-error {{invalid operands to binary expression}} - local_int8 ^ init_int8; // expected-error {{invalid operands to binary expression}} local_int8 << init_int8; // expected-error {{invalid operands to binary expression}} local_int8 >> init_int8; // expected-error {{invalid operands to binary expression}} local_int8 < init_int8; // expected-error {{invalid operands to binary expression}} @@ -225,9 +221,6 @@ void func(int sel) { local_int8 &&init_int8; // expected-error {{invalid operands to binary expression}} expected-error {{not contextually convertible}} local_int8 || init_int8; // expected-error {{invalid operands to binary expression}} expected-error {{not contextually convertible}} - local_int8 &= init_int8; // expected-error {{invalid operands to binary expression}} - local_int8 |= init_int8; // expected-error {{invalid operands to binary expression}} - local_int8 ^= init_int8; // expected-error {{invalid operands to binary expression}} local_int8 <<= init_int8; // expected-error {{invalid operands to binary expression}} local_int8 >>= init_int8; // expected-error {{invalid operands to binary expression}}