// NOTE: Assertions have been autogenerated by utils/update_cc_test_checks.py // RUN: %clang_cc1 -triple aarch64-none-linux-gnu -target-feature +sve \ // RUN: -disable-O0-optnone \ // RUN: -emit-llvm -o - %s | opt -S -passes=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, i64 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, i64 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, i64 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, i64 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, i64 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, i64 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, i64 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, i64 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, i64 0), poison, zeroinitializer) // CHECK-NEXT: ret [[NEG]] // svuint64_t neg_u64(svuint64_t a) { return ~a; }