| ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 6 |
| ; RUN: opt -S -passes=instsimplify < %s | FileCheck %s |
| |
| target triple = "aarch64-unknown-linux-gnu" |
| |
| ; |
| ; ANDV |
| ; |
| |
| define i8 @andv_i8_no_active(<vscale x 16 x i8> %a) #0 { |
| ; CHECK-LABEL: define i8 @andv_i8_no_active( |
| ; CHECK-SAME: <vscale x 16 x i8> [[A:%.*]]) #[[ATTR0:[0-9]+]] { |
| ; CHECK-NEXT: ret i8 -1 |
| ; |
| %out = call i8 @llvm.aarch64.sve.andv.nxv16i8(<vscale x 16 x i1> zeroinitializer, <vscale x 16 x i8> %a) |
| ret i8 %out |
| } |
| |
| define i8 @andv_i8_splat_neutral_val(<vscale x 16 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i8 @andv_i8_splat_neutral_val( |
| ; CHECK-SAME: <vscale x 16 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i8 -1 |
| ; |
| %out = call i8 @llvm.aarch64.sve.andv.nxv16i8(<vscale x 16 x i1> %pg, <vscale x 16 x i8> splat(i8 -1)) |
| ret i8 %out |
| } |
| |
| define i8 @andv_i8_splat_non_neutral_val(<vscale x 16 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i8 @andv_i8_splat_non_neutral_val( |
| ; CHECK-SAME: <vscale x 16 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[OUT:%.*]] = call i8 @llvm.aarch64.sve.andv.nxv16i8(<vscale x 16 x i1> [[PG]], <vscale x 16 x i8> zeroinitializer) |
| ; CHECK-NEXT: ret i8 [[OUT]] |
| ; |
| %out = call i8 @llvm.aarch64.sve.andv.nxv16i8(<vscale x 16 x i1> %pg, <vscale x 16 x i8> zeroinitializer) |
| ret i8 %out |
| } |
| |
| define i8 @andv_i8_all_active_splat(i8 %a) #0 { |
| ; CHECK-LABEL: define i8 @andv_i8_all_active_splat( |
| ; CHECK-SAME: i8 [[A:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i8 [[A]] |
| ; |
| %a.insert = insertelement <vscale x 16 x i8> poison, i8 %a, i8 0 |
| %a.splat = shufflevector <vscale x 16 x i8> %a.insert, <vscale x 16 x i8> poison, <vscale x 16 x i32> zeroinitializer |
| %out = call i8 @llvm.aarch64.sve.andv.nxv16i8(<vscale x 16 x i1> splat (i1 true), <vscale x 16 x i8> %a.splat) |
| ret i8 %out |
| } |
| |
| define i16 @andv_i16_splat_neutral_val(<vscale x 8 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i16 @andv_i16_splat_neutral_val( |
| ; CHECK-SAME: <vscale x 8 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i16 -1 |
| ; |
| %out = call i16 @llvm.aarch64.sve.andv.nxv8i16(<vscale x 8 x i1> %pg, <vscale x 8 x i16> splat(i16 -1)) |
| ret i16 %out |
| } |
| |
| define i16 @andv_i16_splat_non_neutral_val(<vscale x 8 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i16 @andv_i16_splat_non_neutral_val( |
| ; CHECK-SAME: <vscale x 8 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[OUT:%.*]] = call i16 @llvm.aarch64.sve.andv.nxv8i16(<vscale x 8 x i1> [[PG]], <vscale x 8 x i16> zeroinitializer) |
| ; CHECK-NEXT: ret i16 [[OUT]] |
| ; |
| %out = call i16 @llvm.aarch64.sve.andv.nxv8i16(<vscale x 8 x i1> %pg, <vscale x 8 x i16> zeroinitializer) |
| ret i16 %out |
| } |
| |
| define i32 @andv_i32_splat_neutral_val(<vscale x 4 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i32 @andv_i32_splat_neutral_val( |
| ; CHECK-SAME: <vscale x 4 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i32 -1 |
| ; |
| %out = call i32 @llvm.aarch64.sve.andv.nxv4i32(<vscale x 4 x i1> %pg, <vscale x 4 x i32> splat(i32 -1)) |
| ret i32 %out |
| } |
| |
| define i32 @andv_i32_splat_non_neutral_val(<vscale x 4 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i32 @andv_i32_splat_non_neutral_val( |
| ; CHECK-SAME: <vscale x 4 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[OUT:%.*]] = call i32 @llvm.aarch64.sve.andv.nxv4i32(<vscale x 4 x i1> [[PG]], <vscale x 4 x i32> zeroinitializer) |
| ; CHECK-NEXT: ret i32 [[OUT]] |
| ; |
| %out = call i32 @llvm.aarch64.sve.andv.nxv4i32(<vscale x 4 x i1> %pg, <vscale x 4 x i32> zeroinitializer) |
| ret i32 %out |
| } |
| |
| define i64 @andv_i64_splat_neutral_val(<vscale x 2 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i64 @andv_i64_splat_neutral_val( |
| ; CHECK-SAME: <vscale x 2 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i64 -1 |
| ; |
| %out = call i64 @llvm.aarch64.sve.andv.nxv2i64(<vscale x 2 x i1> %pg, <vscale x 2 x i64> splat(i64 -1)) |
| ret i64 %out |
| } |
| |
| define i64 @andv_i64_splat_non_neutral_val(<vscale x 2 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i64 @andv_i64_splat_non_neutral_val( |
| ; CHECK-SAME: <vscale x 2 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[OUT:%.*]] = call i64 @llvm.aarch64.sve.andv.nxv2i64(<vscale x 2 x i1> [[PG]], <vscale x 2 x i64> zeroinitializer) |
| ; CHECK-NEXT: ret i64 [[OUT]] |
| ; |
| %out = call i64 @llvm.aarch64.sve.andv.nxv2i64(<vscale x 2 x i1> %pg, <vscale x 2 x i64> zeroinitializer) |
| ret i64 %out |
| } |
| |
| ; |
| ; EORV |
| ; |
| |
| define i8 @eorv_i8_no_active(<vscale x 16 x i8> %a) #0 { |
| ; CHECK-LABEL: define i8 @eorv_i8_no_active( |
| ; CHECK-SAME: <vscale x 16 x i8> [[A:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i8 0 |
| ; |
| %out = call i8 @llvm.aarch64.sve.eorv.nxv16i8(<vscale x 16 x i1> zeroinitializer, <vscale x 16 x i8> %a) |
| ret i8 %out |
| } |
| |
| define i8 @eorv_i8_splat_neutral_val(<vscale x 16 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i8 @eorv_i8_splat_neutral_val( |
| ; CHECK-SAME: <vscale x 16 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i8 0 |
| ; |
| %out = call i8 @llvm.aarch64.sve.eorv.nxv16i8(<vscale x 16 x i1> %pg, <vscale x 16 x i8> zeroinitializer) |
| ret i8 %out |
| } |
| |
| define i8 @eorv_i8_splat_non_neutral_val(<vscale x 16 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i8 @eorv_i8_splat_non_neutral_val( |
| ; CHECK-SAME: <vscale x 16 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[OUT:%.*]] = call i8 @llvm.aarch64.sve.eorv.nxv16i8(<vscale x 16 x i1> [[PG]], <vscale x 16 x i8> splat (i8 1)) |
| ; CHECK-NEXT: ret i8 [[OUT]] |
| ; |
| %out = call i8 @llvm.aarch64.sve.eorv.nxv16i8(<vscale x 16 x i1> %pg, <vscale x 16 x i8> splat(i8 1)) |
| ret i8 %out |
| } |
| |
| define i8 @eorv_i8_all_active_splat(i8 %a) #0 { |
| ; CHECK-LABEL: define i8 @eorv_i8_all_active_splat( |
| ; CHECK-SAME: i8 [[A:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i8 0 |
| ; |
| %a.insert = insertelement <vscale x 16 x i8> poison, i8 %a, i8 0 |
| %a.splat = shufflevector <vscale x 16 x i8> %a.insert, <vscale x 16 x i8> poison, <vscale x 16 x i32> zeroinitializer |
| %out = call i8 @llvm.aarch64.sve.eorv.nxv16i8(<vscale x 16 x i1> splat (i1 true), <vscale x 16 x i8> %a.splat) |
| ret i8 %out |
| } |
| |
| define i8 @eorv_i8_all_active_non_splat(<vscale x 16 x i8> %a) #0 { |
| ; CHECK-LABEL: define i8 @eorv_i8_all_active_non_splat( |
| ; CHECK-SAME: <vscale x 16 x i8> [[A:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[OUT:%.*]] = call i8 @llvm.aarch64.sve.eorv.nxv16i8(<vscale x 16 x i1> splat (i1 true), <vscale x 16 x i8> [[A]]) |
| ; CHECK-NEXT: ret i8 [[OUT]] |
| ; |
| %out = call i8 @llvm.aarch64.sve.eorv.nxv16i8(<vscale x 16 x i1> splat (i1 true), <vscale x 16 x i8> %a) |
| ret i8 %out |
| } |
| |
| define i16 @eorv_i16_splat_neutral_val(<vscale x 8 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i16 @eorv_i16_splat_neutral_val( |
| ; CHECK-SAME: <vscale x 8 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i16 0 |
| ; |
| %out = call i16 @llvm.aarch64.sve.eorv.nxv8i16(<vscale x 8 x i1> %pg, <vscale x 8 x i16> zeroinitializer) |
| ret i16 %out |
| } |
| |
| define i16 @eorv_i16_splat_non_neutral_val(<vscale x 8 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i16 @eorv_i16_splat_non_neutral_val( |
| ; CHECK-SAME: <vscale x 8 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[OUT:%.*]] = call i16 @llvm.aarch64.sve.eorv.nxv8i16(<vscale x 8 x i1> [[PG]], <vscale x 8 x i16> splat (i16 1)) |
| ; CHECK-NEXT: ret i16 [[OUT]] |
| ; |
| %out = call i16 @llvm.aarch64.sve.eorv.nxv8i16(<vscale x 8 x i1> %pg, <vscale x 8 x i16> splat(i16 1)) |
| ret i16 %out |
| } |
| |
| define i32 @eorv_i32_splat_neutral_val(<vscale x 4 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i32 @eorv_i32_splat_neutral_val( |
| ; CHECK-SAME: <vscale x 4 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i32 0 |
| ; |
| %out = call i32 @llvm.aarch64.sve.eorv.nxv4i32(<vscale x 4 x i1> %pg, <vscale x 4 x i32> zeroinitializer) |
| ret i32 %out |
| } |
| |
| define i32 @eorv_i32_splat_non_neutral_val(<vscale x 4 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i32 @eorv_i32_splat_non_neutral_val( |
| ; CHECK-SAME: <vscale x 4 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[OUT:%.*]] = call i32 @llvm.aarch64.sve.eorv.nxv4i32(<vscale x 4 x i1> [[PG]], <vscale x 4 x i32> splat (i32 1)) |
| ; CHECK-NEXT: ret i32 [[OUT]] |
| ; |
| %out = call i32 @llvm.aarch64.sve.eorv.nxv4i32(<vscale x 4 x i1> %pg, <vscale x 4 x i32> splat(i32 1)) |
| ret i32 %out |
| } |
| |
| define i64 @eorv_i64_splat_neutral_val(<vscale x 2 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i64 @eorv_i64_splat_neutral_val( |
| ; CHECK-SAME: <vscale x 2 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i64 0 |
| ; |
| %out = call i64 @llvm.aarch64.sve.eorv.nxv2i64(<vscale x 2 x i1> %pg, <vscale x 2 x i64> zeroinitializer) |
| ret i64 %out |
| } |
| |
| define i64 @eorv_i64_splat_non_neutral_val(<vscale x 2 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i64 @eorv_i64_splat_non_neutral_val( |
| ; CHECK-SAME: <vscale x 2 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[OUT:%.*]] = call i64 @llvm.aarch64.sve.eorv.nxv2i64(<vscale x 2 x i1> [[PG]], <vscale x 2 x i64> splat (i64 1)) |
| ; CHECK-NEXT: ret i64 [[OUT]] |
| ; |
| %out = call i64 @llvm.aarch64.sve.eorv.nxv2i64(<vscale x 2 x i1> %pg, <vscale x 2 x i64> splat(i64 1)) |
| ret i64 %out |
| } |
| |
| ; |
| ; ORV |
| ; |
| |
| define i8 @orv_i8_no_active(<vscale x 16 x i8> %a) #0 { |
| ; CHECK-LABEL: define i8 @orv_i8_no_active( |
| ; CHECK-SAME: <vscale x 16 x i8> [[A:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i8 0 |
| ; |
| %out = call i8 @llvm.aarch64.sve.orv.nxv16i8(<vscale x 16 x i1> zeroinitializer, <vscale x 16 x i8> %a) |
| ret i8 %out |
| } |
| |
| define i8 @orv_i8_splat_neutral_val(<vscale x 16 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i8 @orv_i8_splat_neutral_val( |
| ; CHECK-SAME: <vscale x 16 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i8 0 |
| ; |
| %out = call i8 @llvm.aarch64.sve.orv.nxv16i8(<vscale x 16 x i1> %pg, <vscale x 16 x i8> zeroinitializer) |
| ret i8 %out |
| } |
| |
| define i8 @orv_i8_splat_non_neutral_val(<vscale x 16 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i8 @orv_i8_splat_non_neutral_val( |
| ; CHECK-SAME: <vscale x 16 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[OUT:%.*]] = call i8 @llvm.aarch64.sve.orv.nxv16i8(<vscale x 16 x i1> [[PG]], <vscale x 16 x i8> splat (i8 1)) |
| ; CHECK-NEXT: ret i8 [[OUT]] |
| ; |
| %out = call i8 @llvm.aarch64.sve.orv.nxv16i8(<vscale x 16 x i1> %pg, <vscale x 16 x i8> splat(i8 1)) |
| ret i8 %out |
| } |
| |
| define i8 @orv_i8_all_active_splat(i8 %a) #0 { |
| ; CHECK-LABEL: define i8 @orv_i8_all_active_splat( |
| ; CHECK-SAME: i8 [[A:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i8 [[A]] |
| ; |
| %a.insert = insertelement <vscale x 16 x i8> poison, i8 %a, i8 0 |
| %a.splat = shufflevector <vscale x 16 x i8> %a.insert, <vscale x 16 x i8> poison, <vscale x 16 x i32> zeroinitializer |
| %out = call i8 @llvm.aarch64.sve.orv.nxv16i8(<vscale x 16 x i1> splat (i1 true), <vscale x 16 x i8> %a.splat) |
| ret i8 %out |
| } |
| |
| define i16 @orv_i16_splat_neutral_val(<vscale x 8 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i16 @orv_i16_splat_neutral_val( |
| ; CHECK-SAME: <vscale x 8 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i16 0 |
| ; |
| %out = call i16 @llvm.aarch64.sve.orv.nxv8i16(<vscale x 8 x i1> %pg, <vscale x 8 x i16> zeroinitializer) |
| ret i16 %out |
| } |
| |
| define i16 @orv_i16_splat_non_neutral_val(<vscale x 8 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i16 @orv_i16_splat_non_neutral_val( |
| ; CHECK-SAME: <vscale x 8 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[OUT:%.*]] = call i16 @llvm.aarch64.sve.orv.nxv8i16(<vscale x 8 x i1> [[PG]], <vscale x 8 x i16> splat (i16 1)) |
| ; CHECK-NEXT: ret i16 [[OUT]] |
| ; |
| %out = call i16 @llvm.aarch64.sve.orv.nxv8i16(<vscale x 8 x i1> %pg, <vscale x 8 x i16> splat(i16 1)) |
| ret i16 %out |
| } |
| |
| define i32 @orv_i32_splat_neutral_val(<vscale x 4 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i32 @orv_i32_splat_neutral_val( |
| ; CHECK-SAME: <vscale x 4 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i32 0 |
| ; |
| %out = call i32 @llvm.aarch64.sve.orv.nxv4i32(<vscale x 4 x i1> %pg, <vscale x 4 x i32> zeroinitializer) |
| ret i32 %out |
| } |
| |
| define i32 @orv_i32_splat_non_neutral_val(<vscale x 4 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i32 @orv_i32_splat_non_neutral_val( |
| ; CHECK-SAME: <vscale x 4 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[OUT:%.*]] = call i32 @llvm.aarch64.sve.orv.nxv4i32(<vscale x 4 x i1> [[PG]], <vscale x 4 x i32> splat (i32 1)) |
| ; CHECK-NEXT: ret i32 [[OUT]] |
| ; |
| %out = call i32 @llvm.aarch64.sve.orv.nxv4i32(<vscale x 4 x i1> %pg, <vscale x 4 x i32> splat(i32 1)) |
| ret i32 %out |
| } |
| |
| define i64 @orv_i64_splat_neutral_val(<vscale x 2 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i64 @orv_i64_splat_neutral_val( |
| ; CHECK-SAME: <vscale x 2 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i64 0 |
| ; |
| %out = call i64 @llvm.aarch64.sve.orv.nxv2i64(<vscale x 2 x i1> %pg, <vscale x 2 x i64> zeroinitializer) |
| ret i64 %out |
| } |
| |
| define i64 @orv_i64_splat_non_neutral_val(<vscale x 2 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i64 @orv_i64_splat_non_neutral_val( |
| ; CHECK-SAME: <vscale x 2 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[OUT:%.*]] = call i64 @llvm.aarch64.sve.orv.nxv2i64(<vscale x 2 x i1> [[PG]], <vscale x 2 x i64> splat (i64 1)) |
| ; CHECK-NEXT: ret i64 [[OUT]] |
| ; |
| %out = call i64 @llvm.aarch64.sve.orv.nxv2i64(<vscale x 2 x i1> %pg, <vscale x 2 x i64> splat(i64 1)) |
| ret i64 %out |
| } |
| |
| ; |
| ; SADDV |
| ; |
| |
| define i64 @saddv_i8_no_active(<vscale x 16 x i8> %a) #0 { |
| ; CHECK-LABEL: define i64 @saddv_i8_no_active( |
| ; CHECK-SAME: <vscale x 16 x i8> [[A:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i64 0 |
| ; |
| %out = call i64 @llvm.aarch64.sve.saddv.nxv16i8(<vscale x 16 x i1> zeroinitializer, <vscale x 16 x i8> %a) |
| ret i64 %out |
| } |
| |
| define i64 @saddv_i8_splat_neutral_val(<vscale x 16 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i64 @saddv_i8_splat_neutral_val( |
| ; CHECK-SAME: <vscale x 16 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i64 0 |
| ; |
| %out = call i64 @llvm.aarch64.sve.saddv.nxv16i8(<vscale x 16 x i1> %pg, <vscale x 16 x i8> zeroinitializer) |
| ret i64 %out |
| } |
| |
| define i64 @saddv_i8_splat_non_neutral_val(<vscale x 16 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i64 @saddv_i8_splat_non_neutral_val( |
| ; CHECK-SAME: <vscale x 16 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[OUT:%.*]] = call i64 @llvm.aarch64.sve.saddv.nxv16i8(<vscale x 16 x i1> [[PG]], <vscale x 16 x i8> splat (i8 1)) |
| ; CHECK-NEXT: ret i64 [[OUT]] |
| ; |
| %out = call i64 @llvm.aarch64.sve.saddv.nxv16i8(<vscale x 16 x i1> %pg, <vscale x 16 x i8> splat(i8 1)) |
| ret i64 %out |
| } |
| |
| define i64 @saddv_i8_all_active_splat(i8 %a) #0 { |
| ; CHECK-LABEL: define i64 @saddv_i8_all_active_splat( |
| ; CHECK-SAME: i8 [[A:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[A_INSERT:%.*]] = insertelement <vscale x 16 x i8> poison, i8 [[A]], i8 0 |
| ; CHECK-NEXT: [[A_SPLAT:%.*]] = shufflevector <vscale x 16 x i8> [[A_INSERT]], <vscale x 16 x i8> poison, <vscale x 16 x i32> zeroinitializer |
| ; CHECK-NEXT: [[OUT:%.*]] = call i64 @llvm.aarch64.sve.saddv.nxv16i8(<vscale x 16 x i1> splat (i1 true), <vscale x 16 x i8> [[A_SPLAT]]) |
| ; CHECK-NEXT: ret i64 [[OUT]] |
| ; |
| %a.insert = insertelement <vscale x 16 x i8> poison, i8 %a, i8 0 |
| %a.splat = shufflevector <vscale x 16 x i8> %a.insert, <vscale x 16 x i8> poison, <vscale x 16 x i32> zeroinitializer |
| %out = call i64 @llvm.aarch64.sve.saddv.nxv16i8(<vscale x 16 x i1> splat (i1 true), <vscale x 16 x i8> %a.splat) |
| ret i64 %out |
| } |
| |
| define i64 @saddv_i16_splat_neutral_val(<vscale x 8 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i64 @saddv_i16_splat_neutral_val( |
| ; CHECK-SAME: <vscale x 8 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i64 0 |
| ; |
| %out = call i64 @llvm.aarch64.sve.saddv.nxv8i16(<vscale x 8 x i1> %pg, <vscale x 8 x i16> zeroinitializer) |
| ret i64 %out |
| } |
| |
| define i64 @saddv_i16_splat_non_neutral_val(<vscale x 8 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i64 @saddv_i16_splat_non_neutral_val( |
| ; CHECK-SAME: <vscale x 8 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[OUT:%.*]] = call i64 @llvm.aarch64.sve.saddv.nxv8i16(<vscale x 8 x i1> [[PG]], <vscale x 8 x i16> splat (i16 1)) |
| ; CHECK-NEXT: ret i64 [[OUT]] |
| ; |
| %out = call i64 @llvm.aarch64.sve.saddv.nxv8i16(<vscale x 8 x i1> %pg, <vscale x 8 x i16> splat(i16 1)) |
| ret i64 %out |
| } |
| |
| define i64 @saddv_i32_splat_neutral_val(<vscale x 4 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i64 @saddv_i32_splat_neutral_val( |
| ; CHECK-SAME: <vscale x 4 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i64 0 |
| ; |
| %out = call i64 @llvm.aarch64.sve.saddv.nxv4i32(<vscale x 4 x i1> %pg, <vscale x 4 x i32> zeroinitializer) |
| ret i64 %out |
| } |
| |
| define i64 @saddv_i32_splat_non_neutral_val(<vscale x 4 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i64 @saddv_i32_splat_non_neutral_val( |
| ; CHECK-SAME: <vscale x 4 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[OUT:%.*]] = call i64 @llvm.aarch64.sve.saddv.nxv4i32(<vscale x 4 x i1> [[PG]], <vscale x 4 x i32> splat (i32 1)) |
| ; CHECK-NEXT: ret i64 [[OUT]] |
| ; |
| %out = call i64 @llvm.aarch64.sve.saddv.nxv4i32(<vscale x 4 x i1> %pg, <vscale x 4 x i32> splat(i32 1)) |
| ret i64 %out |
| } |
| |
| define i64 @saddv_i64_splat_neutral_val(<vscale x 2 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i64 @saddv_i64_splat_neutral_val( |
| ; CHECK-SAME: <vscale x 2 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i64 0 |
| ; |
| %out = call i64 @llvm.aarch64.sve.saddv.nxv2i64(<vscale x 2 x i1> %pg, <vscale x 2 x i64> zeroinitializer) |
| ret i64 %out |
| } |
| |
| define i64 @saddv_i64_splat_non_neutral_val(<vscale x 2 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i64 @saddv_i64_splat_non_neutral_val( |
| ; CHECK-SAME: <vscale x 2 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[OUT:%.*]] = call i64 @llvm.aarch64.sve.saddv.nxv2i64(<vscale x 2 x i1> [[PG]], <vscale x 2 x i64> splat (i64 1)) |
| ; CHECK-NEXT: ret i64 [[OUT]] |
| ; |
| %out = call i64 @llvm.aarch64.sve.saddv.nxv2i64(<vscale x 2 x i1> %pg, <vscale x 2 x i64> splat(i64 1)) |
| ret i64 %out |
| } |
| |
| ; |
| ; SMAXV |
| ; |
| |
| define i8 @smaxv_i8_no_active(<vscale x 16 x i8> %a) #0 { |
| ; CHECK-LABEL: define i8 @smaxv_i8_no_active( |
| ; CHECK-SAME: <vscale x 16 x i8> [[A:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i8 -128 |
| ; |
| %out = call i8 @llvm.aarch64.sve.smaxv.nxv16i8(<vscale x 16 x i1> zeroinitializer, <vscale x 16 x i8> %a) |
| ret i8 %out |
| } |
| |
| define i8 @smaxv_i8_splat_neutral_val(<vscale x 16 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i8 @smaxv_i8_splat_neutral_val( |
| ; CHECK-SAME: <vscale x 16 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i8 -128 |
| ; |
| %out = call i8 @llvm.aarch64.sve.smaxv.nxv16i8(<vscale x 16 x i1> %pg, <vscale x 16 x i8> splat(i8 -128)) |
| ret i8 %out |
| } |
| |
| define i8 @smaxv_i8_splat_non_neutral_val(<vscale x 16 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i8 @smaxv_i8_splat_non_neutral_val( |
| ; CHECK-SAME: <vscale x 16 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[OUT:%.*]] = call i8 @llvm.aarch64.sve.smaxv.nxv16i8(<vscale x 16 x i1> [[PG]], <vscale x 16 x i8> zeroinitializer) |
| ; CHECK-NEXT: ret i8 [[OUT]] |
| ; |
| %out = call i8 @llvm.aarch64.sve.smaxv.nxv16i8(<vscale x 16 x i1> %pg, <vscale x 16 x i8> zeroinitializer) |
| ret i8 %out |
| } |
| |
| define i8 @smaxv_i8_all_active_splat(i8 %a) #0 { |
| ; CHECK-LABEL: define i8 @smaxv_i8_all_active_splat( |
| ; CHECK-SAME: i8 [[A:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i8 [[A]] |
| ; |
| %a.insert = insertelement <vscale x 16 x i8> poison, i8 %a, i8 0 |
| %a.splat = shufflevector <vscale x 16 x i8> %a.insert, <vscale x 16 x i8> poison, <vscale x 16 x i32> zeroinitializer |
| %out = call i8 @llvm.aarch64.sve.smaxv.nxv16i8(<vscale x 16 x i1> splat (i1 true), <vscale x 16 x i8> %a.splat) |
| ret i8 %out |
| } |
| |
| define i16 @smaxv_i16_splat_neutral_val(<vscale x 8 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i16 @smaxv_i16_splat_neutral_val( |
| ; CHECK-SAME: <vscale x 8 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i16 -32768 |
| ; |
| %out = call i16 @llvm.aarch64.sve.smaxv.nxv8i16(<vscale x 8 x i1> %pg, <vscale x 8 x i16> splat(i16 -32768)) |
| ret i16 %out |
| } |
| |
| define i16 @smaxv_i16_splat_non_neutral_val(<vscale x 8 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i16 @smaxv_i16_splat_non_neutral_val( |
| ; CHECK-SAME: <vscale x 8 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[OUT:%.*]] = call i16 @llvm.aarch64.sve.smaxv.nxv8i16(<vscale x 8 x i1> [[PG]], <vscale x 8 x i16> zeroinitializer) |
| ; CHECK-NEXT: ret i16 [[OUT]] |
| ; |
| %out = call i16 @llvm.aarch64.sve.smaxv.nxv8i16(<vscale x 8 x i1> %pg, <vscale x 8 x i16> zeroinitializer) |
| ret i16 %out |
| } |
| |
| define i32 @smaxv_i32_splat_neutral_val(<vscale x 4 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i32 @smaxv_i32_splat_neutral_val( |
| ; CHECK-SAME: <vscale x 4 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i32 -2147483648 |
| ; |
| %out = call i32 @llvm.aarch64.sve.smaxv.nxv4i32(<vscale x 4 x i1> %pg, <vscale x 4 x i32> splat(i32 -2147483648)) |
| ret i32 %out |
| } |
| |
| define i32 @smaxv_i32_splat_non_neutral_val(<vscale x 4 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i32 @smaxv_i32_splat_non_neutral_val( |
| ; CHECK-SAME: <vscale x 4 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[OUT:%.*]] = call i32 @llvm.aarch64.sve.smaxv.nxv4i32(<vscale x 4 x i1> [[PG]], <vscale x 4 x i32> zeroinitializer) |
| ; CHECK-NEXT: ret i32 [[OUT]] |
| ; |
| %out = call i32 @llvm.aarch64.sve.smaxv.nxv4i32(<vscale x 4 x i1> %pg, <vscale x 4 x i32> zeroinitializer) |
| ret i32 %out |
| } |
| |
| define i64 @smaxv_i64_splat_neutral_val(<vscale x 2 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i64 @smaxv_i64_splat_neutral_val( |
| ; CHECK-SAME: <vscale x 2 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i64 -9223372036854775808 |
| ; |
| %out = call i64 @llvm.aarch64.sve.smaxv.nxv2i64(<vscale x 2 x i1> %pg, <vscale x 2 x i64> splat(i64 -9223372036854775808)) |
| ret i64 %out |
| } |
| |
| define i64 @smaxv_i64_splat_non_neutral_val(<vscale x 2 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i64 @smaxv_i64_splat_non_neutral_val( |
| ; CHECK-SAME: <vscale x 2 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[OUT:%.*]] = call i64 @llvm.aarch64.sve.smaxv.nxv2i64(<vscale x 2 x i1> [[PG]], <vscale x 2 x i64> zeroinitializer) |
| ; CHECK-NEXT: ret i64 [[OUT]] |
| ; |
| %out = call i64 @llvm.aarch64.sve.smaxv.nxv2i64(<vscale x 2 x i1> %pg, <vscale x 2 x i64> zeroinitializer) |
| ret i64 %out |
| } |
| |
| ; |
| ; SMINV |
| ; |
| |
| define i8 @sminv_i8_no_active(<vscale x 16 x i8> %a) #0 { |
| ; CHECK-LABEL: define i8 @sminv_i8_no_active( |
| ; CHECK-SAME: <vscale x 16 x i8> [[A:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i8 127 |
| ; |
| %out = call i8 @llvm.aarch64.sve.sminv.nxv16i8(<vscale x 16 x i1> zeroinitializer, <vscale x 16 x i8> %a) |
| ret i8 %out |
| } |
| |
| define i8 @sminv_i8_splat_neutral_val(<vscale x 16 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i8 @sminv_i8_splat_neutral_val( |
| ; CHECK-SAME: <vscale x 16 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i8 127 |
| ; |
| %out = call i8 @llvm.aarch64.sve.sminv.nxv16i8(<vscale x 16 x i1> %pg, <vscale x 16 x i8> splat(i8 127)) |
| ret i8 %out |
| } |
| |
| define i8 @sminv_i8_splat_non_neutral_val(<vscale x 16 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i8 @sminv_i8_splat_non_neutral_val( |
| ; CHECK-SAME: <vscale x 16 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[OUT:%.*]] = call i8 @llvm.aarch64.sve.sminv.nxv16i8(<vscale x 16 x i1> [[PG]], <vscale x 16 x i8> zeroinitializer) |
| ; CHECK-NEXT: ret i8 [[OUT]] |
| ; |
| %out = call i8 @llvm.aarch64.sve.sminv.nxv16i8(<vscale x 16 x i1> %pg, <vscale x 16 x i8> zeroinitializer) |
| ret i8 %out |
| } |
| |
| define i8 @sminv_i8_all_active_splat(i8 %a) #0 { |
| ; CHECK-LABEL: define i8 @sminv_i8_all_active_splat( |
| ; CHECK-SAME: i8 [[A:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i8 [[A]] |
| ; |
| %a.insert = insertelement <vscale x 16 x i8> poison, i8 %a, i8 0 |
| %a.splat = shufflevector <vscale x 16 x i8> %a.insert, <vscale x 16 x i8> poison, <vscale x 16 x i32> zeroinitializer |
| %out = call i8 @llvm.aarch64.sve.sminv.nxv16i8(<vscale x 16 x i1> splat (i1 true), <vscale x 16 x i8> %a.splat) |
| ret i8 %out |
| } |
| |
| define i16 @sminv_i16_splat_neutral_val(<vscale x 8 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i16 @sminv_i16_splat_neutral_val( |
| ; CHECK-SAME: <vscale x 8 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i16 32767 |
| ; |
| %out = call i16 @llvm.aarch64.sve.sminv.nxv8i16(<vscale x 8 x i1> %pg, <vscale x 8 x i16> splat(i16 32767)) |
| ret i16 %out |
| } |
| |
| define i16 @sminv_i16_splat_non_neutral_val(<vscale x 8 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i16 @sminv_i16_splat_non_neutral_val( |
| ; CHECK-SAME: <vscale x 8 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[OUT:%.*]] = call i16 @llvm.aarch64.sve.sminv.nxv8i16(<vscale x 8 x i1> [[PG]], <vscale x 8 x i16> zeroinitializer) |
| ; CHECK-NEXT: ret i16 [[OUT]] |
| ; |
| %out = call i16 @llvm.aarch64.sve.sminv.nxv8i16(<vscale x 8 x i1> %pg, <vscale x 8 x i16> zeroinitializer) |
| ret i16 %out |
| } |
| |
| define i32 @sminv_i32_splat_neutral_val(<vscale x 4 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i32 @sminv_i32_splat_neutral_val( |
| ; CHECK-SAME: <vscale x 4 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i32 2147483647 |
| ; |
| %out = call i32 @llvm.aarch64.sve.sminv.nxv4i32(<vscale x 4 x i1> %pg, <vscale x 4 x i32> splat(i32 2147483647)) |
| ret i32 %out |
| } |
| |
| define i32 @sminv_i32_splat_non_neutral_val(<vscale x 4 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i32 @sminv_i32_splat_non_neutral_val( |
| ; CHECK-SAME: <vscale x 4 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[OUT:%.*]] = call i32 @llvm.aarch64.sve.sminv.nxv4i32(<vscale x 4 x i1> [[PG]], <vscale x 4 x i32> zeroinitializer) |
| ; CHECK-NEXT: ret i32 [[OUT]] |
| ; |
| %out = call i32 @llvm.aarch64.sve.sminv.nxv4i32(<vscale x 4 x i1> %pg, <vscale x 4 x i32> zeroinitializer) |
| ret i32 %out |
| } |
| |
| define i64 @sminv_i64_splat_neutral_val(<vscale x 2 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i64 @sminv_i64_splat_neutral_val( |
| ; CHECK-SAME: <vscale x 2 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i64 9223372036854775807 |
| ; |
| %out = call i64 @llvm.aarch64.sve.sminv.nxv2i64(<vscale x 2 x i1> %pg, <vscale x 2 x i64> splat(i64 9223372036854775807)) |
| ret i64 %out |
| } |
| |
| define i64 @sminv_i64_splat_non_neutral_val(<vscale x 2 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i64 @sminv_i64_splat_non_neutral_val( |
| ; CHECK-SAME: <vscale x 2 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[OUT:%.*]] = call i64 @llvm.aarch64.sve.sminv.nxv2i64(<vscale x 2 x i1> [[PG]], <vscale x 2 x i64> zeroinitializer) |
| ; CHECK-NEXT: ret i64 [[OUT]] |
| ; |
| %out = call i64 @llvm.aarch64.sve.sminv.nxv2i64(<vscale x 2 x i1> %pg, <vscale x 2 x i64> zeroinitializer) |
| ret i64 %out |
| } |
| |
| ; |
| ; UADDV |
| ; |
| |
| define i64 @uaddv_i8_no_active(<vscale x 16 x i8> %a) #0 { |
| ; CHECK-LABEL: define i64 @uaddv_i8_no_active( |
| ; CHECK-SAME: <vscale x 16 x i8> [[A:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i64 0 |
| ; |
| %out = call i64 @llvm.aarch64.sve.uaddv.nxv16i8(<vscale x 16 x i1> zeroinitializer, <vscale x 16 x i8> %a) |
| ret i64 %out |
| } |
| |
| define i64 @uaddv_i8_splat_neutral_val(<vscale x 16 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i64 @uaddv_i8_splat_neutral_val( |
| ; CHECK-SAME: <vscale x 16 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i64 0 |
| ; |
| %out = call i64 @llvm.aarch64.sve.uaddv.nxv16i8(<vscale x 16 x i1> %pg, <vscale x 16 x i8> zeroinitializer) |
| ret i64 %out |
| } |
| |
| define i64 @uaddv_i8_splat_non_neutral_val(<vscale x 16 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i64 @uaddv_i8_splat_non_neutral_val( |
| ; CHECK-SAME: <vscale x 16 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[OUT:%.*]] = call i64 @llvm.aarch64.sve.uaddv.nxv16i8(<vscale x 16 x i1> [[PG]], <vscale x 16 x i8> splat (i8 1)) |
| ; CHECK-NEXT: ret i64 [[OUT]] |
| ; |
| %out = call i64 @llvm.aarch64.sve.uaddv.nxv16i8(<vscale x 16 x i1> %pg, <vscale x 16 x i8> splat(i8 1)) |
| ret i64 %out |
| } |
| |
| define i64 @uaddv_i8_all_active_splat(i8 %a) #0 { |
| ; CHECK-LABEL: define i64 @uaddv_i8_all_active_splat( |
| ; CHECK-SAME: i8 [[A:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[A_INSERT:%.*]] = insertelement <vscale x 16 x i8> poison, i8 [[A]], i8 0 |
| ; CHECK-NEXT: [[A_SPLAT:%.*]] = shufflevector <vscale x 16 x i8> [[A_INSERT]], <vscale x 16 x i8> poison, <vscale x 16 x i32> zeroinitializer |
| ; CHECK-NEXT: [[OUT:%.*]] = call i64 @llvm.aarch64.sve.uaddv.nxv16i8(<vscale x 16 x i1> splat (i1 true), <vscale x 16 x i8> [[A_SPLAT]]) |
| ; CHECK-NEXT: ret i64 [[OUT]] |
| ; |
| %a.insert = insertelement <vscale x 16 x i8> poison, i8 %a, i8 0 |
| %a.splat = shufflevector <vscale x 16 x i8> %a.insert, <vscale x 16 x i8> poison, <vscale x 16 x i32> zeroinitializer |
| %out = call i64 @llvm.aarch64.sve.uaddv.nxv16i8(<vscale x 16 x i1> splat (i1 true), <vscale x 16 x i8> %a.splat) |
| ret i64 %out |
| } |
| |
| define i64 @uaddv_i16_splat_neutral_val(<vscale x 8 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i64 @uaddv_i16_splat_neutral_val( |
| ; CHECK-SAME: <vscale x 8 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i64 0 |
| ; |
| %out = call i64 @llvm.aarch64.sve.uaddv.nxv8i16(<vscale x 8 x i1> %pg, <vscale x 8 x i16> zeroinitializer) |
| ret i64 %out |
| } |
| |
| define i64 @uaddv_i16_splat_non_neutral_val(<vscale x 8 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i64 @uaddv_i16_splat_non_neutral_val( |
| ; CHECK-SAME: <vscale x 8 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[OUT:%.*]] = call i64 @llvm.aarch64.sve.uaddv.nxv8i16(<vscale x 8 x i1> [[PG]], <vscale x 8 x i16> splat (i16 1)) |
| ; CHECK-NEXT: ret i64 [[OUT]] |
| ; |
| %out = call i64 @llvm.aarch64.sve.uaddv.nxv8i16(<vscale x 8 x i1> %pg, <vscale x 8 x i16> splat(i16 1)) |
| ret i64 %out |
| } |
| |
| define i64 @uaddv_i32_splat_neutral_val(<vscale x 4 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i64 @uaddv_i32_splat_neutral_val( |
| ; CHECK-SAME: <vscale x 4 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i64 0 |
| ; |
| %out = call i64 @llvm.aarch64.sve.uaddv.nxv4i32(<vscale x 4 x i1> %pg, <vscale x 4 x i32> zeroinitializer) |
| ret i64 %out |
| } |
| |
| define i64 @uaddv_i32_splat_non_neutral_val(<vscale x 4 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i64 @uaddv_i32_splat_non_neutral_val( |
| ; CHECK-SAME: <vscale x 4 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[OUT:%.*]] = call i64 @llvm.aarch64.sve.uaddv.nxv4i32(<vscale x 4 x i1> [[PG]], <vscale x 4 x i32> splat (i32 1)) |
| ; CHECK-NEXT: ret i64 [[OUT]] |
| ; |
| %out = call i64 @llvm.aarch64.sve.uaddv.nxv4i32(<vscale x 4 x i1> %pg, <vscale x 4 x i32> splat(i32 1)) |
| ret i64 %out |
| } |
| |
| define i64 @uaddv_i64_splat_neutral_val(<vscale x 2 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i64 @uaddv_i64_splat_neutral_val( |
| ; CHECK-SAME: <vscale x 2 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i64 0 |
| ; |
| %out = call i64 @llvm.aarch64.sve.uaddv.nxv2i64(<vscale x 2 x i1> %pg, <vscale x 2 x i64> zeroinitializer) |
| ret i64 %out |
| } |
| |
| define i64 @uaddv_i64_splat_non_neutral_val(<vscale x 2 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i64 @uaddv_i64_splat_non_neutral_val( |
| ; CHECK-SAME: <vscale x 2 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[OUT:%.*]] = call i64 @llvm.aarch64.sve.uaddv.nxv2i64(<vscale x 2 x i1> [[PG]], <vscale x 2 x i64> splat (i64 1)) |
| ; CHECK-NEXT: ret i64 [[OUT]] |
| ; |
| %out = call i64 @llvm.aarch64.sve.uaddv.nxv2i64(<vscale x 2 x i1> %pg, <vscale x 2 x i64> splat(i64 1)) |
| ret i64 %out |
| } |
| |
| ; |
| ; UMAXV |
| ; |
| |
| define i8 @umaxv_i8_no_active(<vscale x 16 x i8> %a) #0 { |
| ; CHECK-LABEL: define i8 @umaxv_i8_no_active( |
| ; CHECK-SAME: <vscale x 16 x i8> [[A:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i8 0 |
| ; |
| %out = call i8 @llvm.aarch64.sve.umaxv.nxv16i8(<vscale x 16 x i1> zeroinitializer, <vscale x 16 x i8> %a) |
| ret i8 %out |
| } |
| |
| define i8 @umaxv_i8_splat_neutral_val(<vscale x 16 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i8 @umaxv_i8_splat_neutral_val( |
| ; CHECK-SAME: <vscale x 16 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i8 0 |
| ; |
| %out = call i8 @llvm.aarch64.sve.umaxv.nxv16i8(<vscale x 16 x i1> %pg, <vscale x 16 x i8> zeroinitializer) |
| ret i8 %out |
| } |
| |
| define i8 @umaxv_i8_splat_non_neutral_val(<vscale x 16 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i8 @umaxv_i8_splat_non_neutral_val( |
| ; CHECK-SAME: <vscale x 16 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[OUT:%.*]] = call i8 @llvm.aarch64.sve.umaxv.nxv16i8(<vscale x 16 x i1> [[PG]], <vscale x 16 x i8> splat (i8 1)) |
| ; CHECK-NEXT: ret i8 [[OUT]] |
| ; |
| %out = call i8 @llvm.aarch64.sve.umaxv.nxv16i8(<vscale x 16 x i1> %pg, <vscale x 16 x i8> splat(i8 1)) |
| ret i8 %out |
| } |
| |
| define i8 @umaxv_i8_all_active_splat(i8 %a) #0 { |
| ; CHECK-LABEL: define i8 @umaxv_i8_all_active_splat( |
| ; CHECK-SAME: i8 [[A:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i8 [[A]] |
| ; |
| %a.insert = insertelement <vscale x 16 x i8> poison, i8 %a, i8 0 |
| %a.splat = shufflevector <vscale x 16 x i8> %a.insert, <vscale x 16 x i8> poison, <vscale x 16 x i32> zeroinitializer |
| %out = call i8 @llvm.aarch64.sve.umaxv.nxv16i8(<vscale x 16 x i1> splat (i1 true), <vscale x 16 x i8> %a.splat) |
| ret i8 %out |
| } |
| |
| define i16 @umaxv_i16_splat_neutral_val(<vscale x 8 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i16 @umaxv_i16_splat_neutral_val( |
| ; CHECK-SAME: <vscale x 8 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i16 0 |
| ; |
| %out = call i16 @llvm.aarch64.sve.umaxv.nxv8i16(<vscale x 8 x i1> %pg, <vscale x 8 x i16> zeroinitializer) |
| ret i16 %out |
| } |
| |
| define i16 @umaxv_i16_splat_non_neutral_val(<vscale x 8 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i16 @umaxv_i16_splat_non_neutral_val( |
| ; CHECK-SAME: <vscale x 8 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[OUT:%.*]] = call i16 @llvm.aarch64.sve.umaxv.nxv8i16(<vscale x 8 x i1> [[PG]], <vscale x 8 x i16> splat (i16 1)) |
| ; CHECK-NEXT: ret i16 [[OUT]] |
| ; |
| %out = call i16 @llvm.aarch64.sve.umaxv.nxv8i16(<vscale x 8 x i1> %pg, <vscale x 8 x i16> splat(i16 1)) |
| ret i16 %out |
| } |
| |
| define i32 @umaxv_i32_splat_neutral_val(<vscale x 4 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i32 @umaxv_i32_splat_neutral_val( |
| ; CHECK-SAME: <vscale x 4 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i32 0 |
| ; |
| %out = call i32 @llvm.aarch64.sve.umaxv.nxv4i32(<vscale x 4 x i1> %pg, <vscale x 4 x i32> zeroinitializer) |
| ret i32 %out |
| } |
| |
| define i32 @umaxv_i32_splat_non_neutral_val(<vscale x 4 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i32 @umaxv_i32_splat_non_neutral_val( |
| ; CHECK-SAME: <vscale x 4 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[OUT:%.*]] = call i32 @llvm.aarch64.sve.umaxv.nxv4i32(<vscale x 4 x i1> [[PG]], <vscale x 4 x i32> splat (i32 1)) |
| ; CHECK-NEXT: ret i32 [[OUT]] |
| ; |
| %out = call i32 @llvm.aarch64.sve.umaxv.nxv4i32(<vscale x 4 x i1> %pg, <vscale x 4 x i32> splat(i32 1)) |
| ret i32 %out |
| } |
| |
| define i64 @umaxv_i64_splat_neutral_val(<vscale x 2 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i64 @umaxv_i64_splat_neutral_val( |
| ; CHECK-SAME: <vscale x 2 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i64 0 |
| ; |
| %out = call i64 @llvm.aarch64.sve.umaxv.nxv2i64(<vscale x 2 x i1> %pg, <vscale x 2 x i64> zeroinitializer) |
| ret i64 %out |
| } |
| |
| define i64 @umaxv_i64_splat_non_neutral_val(<vscale x 2 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i64 @umaxv_i64_splat_non_neutral_val( |
| ; CHECK-SAME: <vscale x 2 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[OUT:%.*]] = call i64 @llvm.aarch64.sve.umaxv.nxv2i64(<vscale x 2 x i1> [[PG]], <vscale x 2 x i64> splat (i64 1)) |
| ; CHECK-NEXT: ret i64 [[OUT]] |
| ; |
| %out = call i64 @llvm.aarch64.sve.umaxv.nxv2i64(<vscale x 2 x i1> %pg, <vscale x 2 x i64> splat(i64 1)) |
| ret i64 %out |
| } |
| |
| ; |
| ; UMINV |
| ; |
| |
| define i8 @uminv_i8_no_active(<vscale x 16 x i8> %a) #0 { |
| ; CHECK-LABEL: define i8 @uminv_i8_no_active( |
| ; CHECK-SAME: <vscale x 16 x i8> [[A:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i8 -1 |
| ; |
| %out = call i8 @llvm.aarch64.sve.uminv.nxv16i8(<vscale x 16 x i1> zeroinitializer, <vscale x 16 x i8> %a) |
| ret i8 %out |
| } |
| |
| define i8 @uminv_i8_splat_neutral_val(<vscale x 16 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i8 @uminv_i8_splat_neutral_val( |
| ; CHECK-SAME: <vscale x 16 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i8 -1 |
| ; |
| %out = call i8 @llvm.aarch64.sve.uminv.nxv16i8(<vscale x 16 x i1> %pg, <vscale x 16 x i8> splat(i8 -1)) |
| ret i8 %out |
| } |
| |
| define i8 @uminv_i8_splat_non_neutral_val(<vscale x 16 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i8 @uminv_i8_splat_non_neutral_val( |
| ; CHECK-SAME: <vscale x 16 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[OUT:%.*]] = call i8 @llvm.aarch64.sve.uminv.nxv16i8(<vscale x 16 x i1> [[PG]], <vscale x 16 x i8> zeroinitializer) |
| ; CHECK-NEXT: ret i8 [[OUT]] |
| ; |
| %out = call i8 @llvm.aarch64.sve.uminv.nxv16i8(<vscale x 16 x i1> %pg, <vscale x 16 x i8> zeroinitializer) |
| ret i8 %out |
| } |
| |
| define i8 @uminv_i8_all_active_splat(i8 %a) #0 { |
| ; CHECK-LABEL: define i8 @uminv_i8_all_active_splat( |
| ; CHECK-SAME: i8 [[A:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i8 [[A]] |
| ; |
| %a.insert = insertelement <vscale x 16 x i8> poison, i8 %a, i8 0 |
| %a.splat = shufflevector <vscale x 16 x i8> %a.insert, <vscale x 16 x i8> poison, <vscale x 16 x i32> zeroinitializer |
| %out = call i8 @llvm.aarch64.sve.uminv.nxv16i8(<vscale x 16 x i1> splat (i1 true), <vscale x 16 x i8> %a.splat) |
| ret i8 %out |
| } |
| |
| define i16 @uminv_i16_splat_neutral_val(<vscale x 8 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i16 @uminv_i16_splat_neutral_val( |
| ; CHECK-SAME: <vscale x 8 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i16 -1 |
| ; |
| %out = call i16 @llvm.aarch64.sve.uminv.nxv8i16(<vscale x 8 x i1> %pg, <vscale x 8 x i16> splat(i16 -1)) |
| ret i16 %out |
| } |
| |
| define i16 @uminv_i16_splat_non_neutral_val(<vscale x 8 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i16 @uminv_i16_splat_non_neutral_val( |
| ; CHECK-SAME: <vscale x 8 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[OUT:%.*]] = call i16 @llvm.aarch64.sve.uminv.nxv8i16(<vscale x 8 x i1> [[PG]], <vscale x 8 x i16> zeroinitializer) |
| ; CHECK-NEXT: ret i16 [[OUT]] |
| ; |
| %out = call i16 @llvm.aarch64.sve.uminv.nxv8i16(<vscale x 8 x i1> %pg, <vscale x 8 x i16> zeroinitializer) |
| ret i16 %out |
| } |
| |
| define i32 @uminv_i32_splat_neutral_val(<vscale x 4 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i32 @uminv_i32_splat_neutral_val( |
| ; CHECK-SAME: <vscale x 4 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i32 -1 |
| ; |
| %out = call i32 @llvm.aarch64.sve.uminv.nxv4i32(<vscale x 4 x i1> %pg, <vscale x 4 x i32> splat(i32 -1)) |
| ret i32 %out |
| } |
| |
| define i32 @uminv_i32_splat_non_neutral_val(<vscale x 4 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i32 @uminv_i32_splat_non_neutral_val( |
| ; CHECK-SAME: <vscale x 4 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[OUT:%.*]] = call i32 @llvm.aarch64.sve.uminv.nxv4i32(<vscale x 4 x i1> [[PG]], <vscale x 4 x i32> zeroinitializer) |
| ; CHECK-NEXT: ret i32 [[OUT]] |
| ; |
| %out = call i32 @llvm.aarch64.sve.uminv.nxv4i32(<vscale x 4 x i1> %pg, <vscale x 4 x i32> zeroinitializer) |
| ret i32 %out |
| } |
| |
| define i64 @uminv_i64_splat_neutral_val(<vscale x 2 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i64 @uminv_i64_splat_neutral_val( |
| ; CHECK-SAME: <vscale x 2 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: ret i64 -1 |
| ; |
| %out = call i64 @llvm.aarch64.sve.uminv.nxv2i64(<vscale x 2 x i1> %pg, <vscale x 2 x i64> splat(i64 -1)) |
| ret i64 %out |
| } |
| |
| define i64 @uminv_i64_splat_non_neutral_val(<vscale x 2 x i1> %pg) #0 { |
| ; CHECK-LABEL: define i64 @uminv_i64_splat_non_neutral_val( |
| ; CHECK-SAME: <vscale x 2 x i1> [[PG:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[OUT:%.*]] = call i64 @llvm.aarch64.sve.uminv.nxv2i64(<vscale x 2 x i1> [[PG]], <vscale x 2 x i64> zeroinitializer) |
| ; CHECK-NEXT: ret i64 [[OUT]] |
| ; |
| %out = call i64 @llvm.aarch64.sve.uminv.nxv2i64(<vscale x 2 x i1> %pg, <vscale x 2 x i64> zeroinitializer) |
| ret i64 %out |
| } |
| |
| attributes #0 = { "target-features"="+sve" } |