2020-02-13 02:31:18 +08:00
|
|
|
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
|
2014-05-24 20:50:23 +08:00
|
|
|
; RUN: llc < %s -verify-machineinstrs -mtriple=aarch64-none-linux-gnu -mattr=+neon | FileCheck %s
|
2013-08-01 17:20:35 +08:00
|
|
|
|
|
|
|
define <8 x i8> @and8xi8(<8 x i8> %a, <8 x i8> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and8xi8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: and v0.8b, v0.8b, v1.8b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = and <8 x i8> %a, %b;
|
|
|
|
ret <8 x i8> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <16 x i8> @and16xi8(<16 x i8> %a, <16 x i8> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and16xi8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: and v0.16b, v0.16b, v1.16b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = and <16 x i8> %a, %b;
|
|
|
|
ret <16 x i8> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
define <8 x i8> @orr8xi8(<8 x i8> %a, <8 x i8> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr8xi8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.8b, v0.8b, v1.8b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = or <8 x i8> %a, %b;
|
|
|
|
ret <8 x i8> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <16 x i8> @orr16xi8(<16 x i8> %a, <16 x i8> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr16xi8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.16b, v0.16b, v1.16b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = or <16 x i8> %a, %b;
|
|
|
|
ret <16 x i8> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
define <8 x i8> @xor8xi8(<8 x i8> %a, <8 x i8> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: xor8xi8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: eor v0.8b, v0.8b, v1.8b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = xor <8 x i8> %a, %b;
|
|
|
|
ret <8 x i8> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <16 x i8> @xor16xi8(<16 x i8> %a, <16 x i8> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: xor16xi8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: eor v0.16b, v0.16b, v1.16b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = xor <16 x i8> %a, %b;
|
|
|
|
ret <16 x i8> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i8> @bsl8xi8_const(<8 x i8> %a, <8 x i8> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: bsl8xi8_const:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: movi d2, #0x00ffff0000ffff
|
2020-02-04 22:51:17 +08:00
|
|
|
; CHECK-NEXT: bif v0.8b, v1.8b, v2.8b
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK-NEXT: ret
|
2014-01-09 02:33:04 +08:00
|
|
|
%tmp1 = and <8 x i8> %a, < i8 -1, i8 -1, i8 0, i8 0, i8 -1, i8 -1, i8 0, i8 0 >
|
|
|
|
%tmp2 = and <8 x i8> %b, < i8 0, i8 0, i8 -1, i8 -1, i8 0, i8 0, i8 -1, i8 -1 >
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp3 = or <8 x i8> %tmp1, %tmp2
|
|
|
|
ret <8 x i8> %tmp3
|
|
|
|
}
|
|
|
|
|
|
|
|
define <16 x i8> @bsl16xi8_const(<16 x i8> %a, <16 x i8> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: bsl16xi8_const:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: movi v2.2d, #0x000000ffffffff
|
2020-02-04 22:51:17 +08:00
|
|
|
; CHECK-NEXT: bif v0.16b, v1.16b, v2.16b
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK-NEXT: ret
|
2014-01-09 02:33:04 +08:00
|
|
|
%tmp1 = and <16 x i8> %a, < i8 -1, i8 -1, i8 -1, i8 -1, i8 0, i8 0, i8 0, i8 0, i8 -1, i8 -1, i8 -1, i8 -1, i8 0, i8 0, i8 0, i8 0 >
|
|
|
|
%tmp2 = and <16 x i8> %b, < i8 0, i8 0, i8 0, i8 0, i8 -1, i8 -1, i8 -1, i8 -1, i8 0, i8 0, i8 0, i8 0, i8 -1, i8 -1, i8 -1, i8 -1 >
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp3 = or <16 x i8> %tmp1, %tmp2
|
|
|
|
ret <16 x i8> %tmp3
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i8> @orn8xi8(<8 x i8> %a, <8 x i8> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orn8xi8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orn v0.8b, v0.8b, v1.8b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = xor <8 x i8> %b, < i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1 >
|
|
|
|
%tmp2 = or <8 x i8> %a, %tmp1
|
|
|
|
ret <8 x i8> %tmp2
|
|
|
|
}
|
|
|
|
|
|
|
|
define <16 x i8> @orn16xi8(<16 x i8> %a, <16 x i8> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orn16xi8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orn v0.16b, v0.16b, v1.16b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = xor <16 x i8> %b, < i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1 >
|
|
|
|
%tmp2 = or <16 x i8> %a, %tmp1
|
|
|
|
ret <16 x i8> %tmp2
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i8> @bic8xi8(<8 x i8> %a, <8 x i8> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: bic8xi8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.8b, v0.8b, v1.8b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = xor <8 x i8> %b, < i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1 >
|
|
|
|
%tmp2 = and <8 x i8> %a, %tmp1
|
|
|
|
ret <8 x i8> %tmp2
|
|
|
|
}
|
|
|
|
|
|
|
|
define <16 x i8> @bic16xi8(<16 x i8> %a, <16 x i8> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: bic16xi8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.16b, v0.16b, v1.16b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = xor <16 x i8> %b, < i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1 >
|
|
|
|
%tmp2 = and <16 x i8> %a, %tmp1
|
|
|
|
ret <16 x i8> %tmp2
|
|
|
|
}
|
|
|
|
|
|
|
|
define <2 x i32> @orrimm2s_lsl0(<2 x i32> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orrimm2s_lsl0:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.2s, #255
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = or <2 x i32> %a, < i32 255, i32 255>
|
|
|
|
ret <2 x i32> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <2 x i32> @orrimm2s_lsl8(<2 x i32> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orrimm2s_lsl8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.2s, #255, lsl #8
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = or <2 x i32> %a, < i32 65280, i32 65280>
|
|
|
|
ret <2 x i32> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <2 x i32> @orrimm2s_lsl16(<2 x i32> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orrimm2s_lsl16:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.2s, #255, lsl #16
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = or <2 x i32> %a, < i32 16711680, i32 16711680>
|
|
|
|
ret <2 x i32> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <2 x i32> @orrimm2s_lsl24(<2 x i32> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orrimm2s_lsl24:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.2s, #255, lsl #24
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = or <2 x i32> %a, < i32 4278190080, i32 4278190080>
|
|
|
|
ret <2 x i32> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i32> @orrimm4s_lsl0(<4 x i32> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orrimm4s_lsl0:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.4s, #255
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = or <4 x i32> %a, < i32 255, i32 255, i32 255, i32 255>
|
|
|
|
ret <4 x i32> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i32> @orrimm4s_lsl8(<4 x i32> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orrimm4s_lsl8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.4s, #255, lsl #8
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = or <4 x i32> %a, < i32 65280, i32 65280, i32 65280, i32 65280>
|
|
|
|
ret <4 x i32> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i32> @orrimm4s_lsl16(<4 x i32> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orrimm4s_lsl16:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.4s, #255, lsl #16
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = or <4 x i32> %a, < i32 16711680, i32 16711680, i32 16711680, i32 16711680>
|
|
|
|
ret <4 x i32> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i32> @orrimm4s_lsl24(<4 x i32> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orrimm4s_lsl24:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.4s, #255, lsl #24
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = or <4 x i32> %a, < i32 4278190080, i32 4278190080, i32 4278190080, i32 4278190080>
|
|
|
|
ret <4 x i32> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i16> @orrimm4h_lsl0(<4 x i16> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orrimm4h_lsl0:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.4h, #255
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = or <4 x i16> %a, < i16 255, i16 255, i16 255, i16 255 >
|
|
|
|
ret <4 x i16> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i16> @orrimm4h_lsl8(<4 x i16> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orrimm4h_lsl8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.4h, #255, lsl #8
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = or <4 x i16> %a, < i16 65280, i16 65280, i16 65280, i16 65280 >
|
|
|
|
ret <4 x i16> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i16> @orrimm8h_lsl0(<8 x i16> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orrimm8h_lsl0:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.8h, #255
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = or <8 x i16> %a, < i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255 >
|
|
|
|
ret <8 x i16> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i16> @orrimm8h_lsl8(<8 x i16> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orrimm8h_lsl8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.8h, #255, lsl #8
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = or <8 x i16> %a, < i16 65280, i16 65280, i16 65280, i16 65280, i16 65280, i16 65280, i16 65280, i16 65280 >
|
|
|
|
ret <8 x i16> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <2 x i32> @bicimm2s_lsl0(<2 x i32> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: bicimm2s_lsl0:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.2s, #16
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = and <2 x i32> %a, < i32 4294967279, i32 4294967279 >
|
|
|
|
ret <2 x i32> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <2 x i32> @bicimm2s_lsl8(<2 x i32> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: bicimm2s_lsl8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.2s, #16, lsl #8
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <2 x i32> %a, < i32 4294963199, i32 4294963199 >
|
2013-08-01 17:20:35 +08:00
|
|
|
ret <2 x i32> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <2 x i32> @bicimm2s_lsl16(<2 x i32> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: bicimm2s_lsl16:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.2s, #16, lsl #16
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <2 x i32> %a, < i32 4293918719, i32 4293918719 >
|
2013-08-01 17:20:35 +08:00
|
|
|
ret <2 x i32> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <2 x i32> @bicimm2s_lsl124(<2 x i32> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: bicimm2s_lsl124:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.2s, #16, lsl #24
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <2 x i32> %a, < i32 4026531839, i32 4026531839>
|
2013-08-01 17:20:35 +08:00
|
|
|
ret <2 x i32> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i32> @bicimm4s_lsl0(<4 x i32> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: bicimm4s_lsl0:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.4s, #16
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = and <4 x i32> %a, < i32 4294967279, i32 4294967279, i32 4294967279, i32 4294967279 >
|
|
|
|
ret <4 x i32> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i32> @bicimm4s_lsl8(<4 x i32> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: bicimm4s_lsl8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.4s, #16, lsl #8
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <4 x i32> %a, < i32 4294963199, i32 4294963199, i32 4294963199, i32 4294963199 >
|
2013-08-01 17:20:35 +08:00
|
|
|
ret <4 x i32> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i32> @bicimm4s_lsl16(<4 x i32> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: bicimm4s_lsl16:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.4s, #16, lsl #16
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <4 x i32> %a, < i32 4293918719, i32 4293918719, i32 4293918719, i32 4293918719 >
|
2013-08-01 17:20:35 +08:00
|
|
|
ret <4 x i32> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i32> @bicimm4s_lsl124(<4 x i32> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: bicimm4s_lsl124:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.4s, #16, lsl #24
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <4 x i32> %a, < i32 4026531839, i32 4026531839, i32 4026531839, i32 4026531839>
|
2013-08-01 17:20:35 +08:00
|
|
|
ret <4 x i32> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i16> @bicimm4h_lsl0_a(<4 x i16> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: bicimm4h_lsl0_a:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.4h, #16
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <4 x i16> %a, < i16 4294967279, i16 4294967279, i16 4294967279, i16 4294967279 >
|
2013-08-01 17:20:35 +08:00
|
|
|
ret <4 x i16> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i16> @bicimm4h_lsl0_b(<4 x i16> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: bicimm4h_lsl0_b:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.4h, #255
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = and <4 x i16> %a, < i16 65280, i16 65280, i16 65280, i16 65280 >
|
|
|
|
ret <4 x i16> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i16> @bicimm4h_lsl8_a(<4 x i16> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: bicimm4h_lsl8_a:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.4h, #16, lsl #8
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <4 x i16> %a, < i16 4294963199, i16 4294963199, i16 4294963199, i16 4294963199>
|
2013-08-01 17:20:35 +08:00
|
|
|
ret <4 x i16> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i16> @bicimm4h_lsl8_b(<4 x i16> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: bicimm4h_lsl8_b:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.4h, #255, lsl #8
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = and <4 x i16> %a, < i16 255, i16 255, i16 255, i16 255>
|
|
|
|
ret <4 x i16> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i16> @bicimm8h_lsl0_a(<8 x i16> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: bicimm8h_lsl0_a:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.8h, #16
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <8 x i16> %a, < i16 4294967279, i16 4294967279, i16 4294967279, i16 4294967279,
|
|
|
|
i16 4294967279, i16 4294967279, i16 4294967279, i16 4294967279 >
|
2013-08-01 17:20:35 +08:00
|
|
|
ret <8 x i16> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i16> @bicimm8h_lsl0_b(<8 x i16> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: bicimm8h_lsl0_b:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.8h, #255
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = and <8 x i16> %a, < i16 65280, i16 65280, i16 65280, i16 65280, i16 65280, i16 65280, i16 65280, i16 65280 >
|
|
|
|
ret <8 x i16> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i16> @bicimm8h_lsl8_a(<8 x i16> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: bicimm8h_lsl8_a:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.8h, #16, lsl #8
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <8 x i16> %a, < i16 4294963199, i16 4294963199, i16 4294963199, i16 4294963199,
|
|
|
|
i16 4294963199, i16 4294963199, i16 4294963199, i16 4294963199>
|
2013-08-01 17:20:35 +08:00
|
|
|
ret <8 x i16> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i16> @bicimm8h_lsl8_b(<8 x i16> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: bicimm8h_lsl8_b:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.8h, #255, lsl #8
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = and <8 x i16> %a, < i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255>
|
|
|
|
ret <8 x i16> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <2 x i32> @and2xi32(<2 x i32> %a, <2 x i32> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and2xi32:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: and v0.8b, v0.8b, v1.8b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = and <2 x i32> %a, %b;
|
|
|
|
ret <2 x i32> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i16> @and4xi16(<4 x i16> %a, <4 x i16> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and4xi16:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: and v0.8b, v0.8b, v1.8b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = and <4 x i16> %a, %b;
|
|
|
|
ret <4 x i16> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <1 x i64> @and1xi64(<1 x i64> %a, <1 x i64> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and1xi64:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: and v0.8b, v0.8b, v1.8b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = and <1 x i64> %a, %b;
|
|
|
|
ret <1 x i64> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i32> @and4xi32(<4 x i32> %a, <4 x i32> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and4xi32:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: and v0.16b, v0.16b, v1.16b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = and <4 x i32> %a, %b;
|
|
|
|
ret <4 x i32> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i16> @and8xi16(<8 x i16> %a, <8 x i16> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and8xi16:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: and v0.16b, v0.16b, v1.16b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = and <8 x i16> %a, %b;
|
|
|
|
ret <8 x i16> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <2 x i64> @and2xi64(<2 x i64> %a, <2 x i64> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and2xi64:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: and v0.16b, v0.16b, v1.16b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = and <2 x i64> %a, %b;
|
|
|
|
ret <2 x i64> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <2 x i32> @orr2xi32(<2 x i32> %a, <2 x i32> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr2xi32:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.8b, v0.8b, v1.8b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = or <2 x i32> %a, %b;
|
|
|
|
ret <2 x i32> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i16> @orr4xi16(<4 x i16> %a, <4 x i16> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr4xi16:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.8b, v0.8b, v1.8b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = or <4 x i16> %a, %b;
|
|
|
|
ret <4 x i16> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <1 x i64> @orr1xi64(<1 x i64> %a, <1 x i64> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr1xi64:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.8b, v0.8b, v1.8b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = or <1 x i64> %a, %b;
|
|
|
|
ret <1 x i64> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i32> @orr4xi32(<4 x i32> %a, <4 x i32> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr4xi32:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.16b, v0.16b, v1.16b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = or <4 x i32> %a, %b;
|
|
|
|
ret <4 x i32> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i16> @orr8xi16(<8 x i16> %a, <8 x i16> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr8xi16:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.16b, v0.16b, v1.16b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = or <8 x i16> %a, %b;
|
|
|
|
ret <8 x i16> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <2 x i64> @orr2xi64(<2 x i64> %a, <2 x i64> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr2xi64:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.16b, v0.16b, v1.16b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = or <2 x i64> %a, %b;
|
|
|
|
ret <2 x i64> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <2 x i32> @eor2xi32(<2 x i32> %a, <2 x i32> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: eor2xi32:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: eor v0.8b, v0.8b, v1.8b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = xor <2 x i32> %a, %b;
|
|
|
|
ret <2 x i32> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i16> @eor4xi16(<4 x i16> %a, <4 x i16> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: eor4xi16:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: eor v0.8b, v0.8b, v1.8b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = xor <4 x i16> %a, %b;
|
|
|
|
ret <4 x i16> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <1 x i64> @eor1xi64(<1 x i64> %a, <1 x i64> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: eor1xi64:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: eor v0.8b, v0.8b, v1.8b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = xor <1 x i64> %a, %b;
|
|
|
|
ret <1 x i64> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i32> @eor4xi32(<4 x i32> %a, <4 x i32> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: eor4xi32:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: eor v0.16b, v0.16b, v1.16b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = xor <4 x i32> %a, %b;
|
|
|
|
ret <4 x i32> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i16> @eor8xi16(<8 x i16> %a, <8 x i16> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: eor8xi16:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: eor v0.16b, v0.16b, v1.16b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = xor <8 x i16> %a, %b;
|
|
|
|
ret <8 x i16> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <2 x i64> @eor2xi64(<2 x i64> %a, <2 x i64> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: eor2xi64:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: eor v0.16b, v0.16b, v1.16b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = xor <2 x i64> %a, %b;
|
|
|
|
ret <2 x i64> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
define <2 x i32> @bic2xi32(<2 x i32> %a, <2 x i32> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: bic2xi32:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.8b, v0.8b, v1.8b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = xor <2 x i32> %b, < i32 -1, i32 -1 >
|
|
|
|
%tmp2 = and <2 x i32> %a, %tmp1
|
|
|
|
ret <2 x i32> %tmp2
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i16> @bic4xi16(<4 x i16> %a, <4 x i16> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: bic4xi16:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.8b, v0.8b, v1.8b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = xor <4 x i16> %b, < i16 -1, i16 -1, i16 -1, i16-1 >
|
|
|
|
%tmp2 = and <4 x i16> %a, %tmp1
|
|
|
|
ret <4 x i16> %tmp2
|
|
|
|
}
|
|
|
|
|
|
|
|
define <1 x i64> @bic1xi64(<1 x i64> %a, <1 x i64> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: bic1xi64:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.8b, v0.8b, v1.8b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = xor <1 x i64> %b, < i64 -1>
|
|
|
|
%tmp2 = and <1 x i64> %a, %tmp1
|
|
|
|
ret <1 x i64> %tmp2
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i32> @bic4xi32(<4 x i32> %a, <4 x i32> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: bic4xi32:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.16b, v0.16b, v1.16b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = xor <4 x i32> %b, < i32 -1, i32 -1, i32 -1, i32 -1>
|
|
|
|
%tmp2 = and <4 x i32> %a, %tmp1
|
|
|
|
ret <4 x i32> %tmp2
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i16> @bic8xi16(<8 x i16> %a, <8 x i16> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: bic8xi16:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.16b, v0.16b, v1.16b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = xor <8 x i16> %b, < i16 -1, i16 -1, i16 -1, i16-1, i16 -1, i16 -1, i16 -1, i16 -1 >
|
|
|
|
%tmp2 = and <8 x i16> %a, %tmp1
|
|
|
|
ret <8 x i16> %tmp2
|
|
|
|
}
|
|
|
|
|
|
|
|
define <2 x i64> @bic2xi64(<2 x i64> %a, <2 x i64> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: bic2xi64:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.16b, v0.16b, v1.16b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = xor <2 x i64> %b, < i64 -1, i64 -1>
|
|
|
|
%tmp2 = and <2 x i64> %a, %tmp1
|
|
|
|
ret <2 x i64> %tmp2
|
|
|
|
}
|
|
|
|
|
|
|
|
define <2 x i32> @orn2xi32(<2 x i32> %a, <2 x i32> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orn2xi32:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orn v0.8b, v0.8b, v1.8b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = xor <2 x i32> %b, < i32 -1, i32 -1 >
|
|
|
|
%tmp2 = or <2 x i32> %a, %tmp1
|
|
|
|
ret <2 x i32> %tmp2
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i16> @orn4xi16(<4 x i16> %a, <4 x i16> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orn4xi16:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orn v0.8b, v0.8b, v1.8b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = xor <4 x i16> %b, < i16 -1, i16 -1, i16 -1, i16-1 >
|
|
|
|
%tmp2 = or <4 x i16> %a, %tmp1
|
|
|
|
ret <4 x i16> %tmp2
|
|
|
|
}
|
|
|
|
|
|
|
|
define <1 x i64> @orn1xi64(<1 x i64> %a, <1 x i64> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orn1xi64:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orn v0.8b, v0.8b, v1.8b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = xor <1 x i64> %b, < i64 -1>
|
|
|
|
%tmp2 = or <1 x i64> %a, %tmp1
|
|
|
|
ret <1 x i64> %tmp2
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i32> @orn4xi32(<4 x i32> %a, <4 x i32> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orn4xi32:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orn v0.16b, v0.16b, v1.16b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = xor <4 x i32> %b, < i32 -1, i32 -1, i32 -1, i32 -1>
|
|
|
|
%tmp2 = or <4 x i32> %a, %tmp1
|
|
|
|
ret <4 x i32> %tmp2
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i16> @orn8xi16(<8 x i16> %a, <8 x i16> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orn8xi16:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orn v0.16b, v0.16b, v1.16b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = xor <8 x i16> %b, < i16 -1, i16 -1, i16 -1, i16-1, i16 -1, i16 -1, i16 -1, i16 -1 >
|
|
|
|
%tmp2 = or <8 x i16> %a, %tmp1
|
|
|
|
ret <8 x i16> %tmp2
|
|
|
|
}
|
|
|
|
|
|
|
|
define <2 x i64> @orn2xi64(<2 x i64> %a, <2 x i64> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orn2xi64:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orn v0.16b, v0.16b, v1.16b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp1 = xor <2 x i64> %b, < i64 -1, i64 -1>
|
|
|
|
%tmp2 = or <2 x i64> %a, %tmp1
|
|
|
|
ret <2 x i64> %tmp2
|
|
|
|
}
|
2014-01-09 02:33:04 +08:00
|
|
|
|
2013-08-01 17:20:35 +08:00
|
|
|
define <2 x i32> @bsl2xi32_const(<2 x i32> %a, <2 x i32> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: bsl2xi32_const:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: movi d2, #0x000000ffffffff
|
2020-02-04 22:51:17 +08:00
|
|
|
; CHECK-NEXT: bif v0.8b, v1.8b, v2.8b
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK-NEXT: ret
|
2014-01-09 02:33:04 +08:00
|
|
|
%tmp1 = and <2 x i32> %a, < i32 -1, i32 0 >
|
|
|
|
%tmp2 = and <2 x i32> %b, < i32 0, i32 -1 >
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp3 = or <2 x i32> %tmp1, %tmp2
|
|
|
|
ret <2 x i32> %tmp3
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
define <4 x i16> @bsl4xi16_const(<4 x i16> %a, <4 x i16> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: bsl4xi16_const:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: movi d2, #0x00ffff0000ffff
|
2020-02-04 22:51:17 +08:00
|
|
|
; CHECK-NEXT: bif v0.8b, v1.8b, v2.8b
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK-NEXT: ret
|
2014-01-09 02:33:04 +08:00
|
|
|
%tmp1 = and <4 x i16> %a, < i16 -1, i16 0, i16 -1,i16 0 >
|
|
|
|
%tmp2 = and <4 x i16> %b, < i16 0, i16 -1,i16 0, i16 -1 >
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp3 = or <4 x i16> %tmp1, %tmp2
|
|
|
|
ret <4 x i16> %tmp3
|
|
|
|
}
|
|
|
|
|
|
|
|
define <1 x i64> @bsl1xi64_const(<1 x i64> %a, <1 x i64> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: bsl1xi64_const:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: movi d2, #0xffffffffffffff00
|
2020-02-04 22:51:17 +08:00
|
|
|
; CHECK-NEXT: bif v0.8b, v1.8b, v2.8b
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK-NEXT: ret
|
[AArch64] Improve code generation of constant vectors
Use the whole gammut of constant immediates available to set up a vector.
Instead of using, for example, `mov w0, #0xffff; dup v0.4s, w0`, which
transfers between register files, use the more efficient `movi v0.4s, #-1`
instead. Not limited to just a few values, but any immediate value that can
be encoded by all the variants of `FMOV`, `MOVI`, `MVNI`, thus eliminating
the need to there be patterns to optimize special cases.
Differential revision: https://reviews.llvm.org/D42133
llvm-svn: 326718
2018-03-06 01:02:47 +08:00
|
|
|
%tmp1 = and <1 x i64> %a, < i64 -256 >
|
|
|
|
%tmp2 = and <1 x i64> %b, < i64 255 >
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp3 = or <1 x i64> %tmp1, %tmp2
|
|
|
|
ret <1 x i64> %tmp3
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i32> @bsl4xi32_const(<4 x i32> %a, <4 x i32> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: bsl4xi32_const:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: movi v2.2d, #0x000000ffffffff
|
2020-02-04 22:51:17 +08:00
|
|
|
; CHECK-NEXT: bif v0.16b, v1.16b, v2.16b
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK-NEXT: ret
|
2014-01-09 02:33:04 +08:00
|
|
|
%tmp1 = and <4 x i32> %a, < i32 -1, i32 0, i32 -1, i32 0 >
|
|
|
|
%tmp2 = and <4 x i32> %b, < i32 0, i32 -1, i32 0, i32 -1 >
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp3 = or <4 x i32> %tmp1, %tmp2
|
|
|
|
ret <4 x i32> %tmp3
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i16> @bsl8xi16_const(<8 x i16> %a, <8 x i16> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: bsl8xi16_const:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: movi v2.2d, #0x000000ffffffff
|
2020-02-04 22:51:17 +08:00
|
|
|
; CHECK-NEXT: bif v0.16b, v1.16b, v2.16b
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK-NEXT: ret
|
2014-01-09 02:33:04 +08:00
|
|
|
%tmp1 = and <8 x i16> %a, < i16 -1, i16 -1, i16 0,i16 0, i16 -1, i16 -1, i16 0,i16 0 >
|
|
|
|
%tmp2 = and <8 x i16> %b, < i16 0, i16 0, i16 -1, i16 -1, i16 0, i16 0, i16 -1, i16 -1 >
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp3 = or <8 x i16> %tmp1, %tmp2
|
|
|
|
ret <8 x i16> %tmp3
|
|
|
|
}
|
|
|
|
|
|
|
|
define <2 x i64> @bsl2xi64_const(<2 x i64> %a, <2 x i64> %b) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: bsl2xi64_const:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: adrp x8, .LCPI75_0
|
|
|
|
; CHECK-NEXT: ldr q2, [x8, :lo12:.LCPI75_0]
|
2020-02-04 22:51:17 +08:00
|
|
|
; CHECK-NEXT: bif v0.16b, v1.16b, v2.16b
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK-NEXT: ret
|
2014-01-09 02:33:04 +08:00
|
|
|
%tmp1 = and <2 x i64> %a, < i64 -1, i64 0 >
|
|
|
|
%tmp2 = and <2 x i64> %b, < i64 0, i64 -1 >
|
2013-08-01 17:20:35 +08:00
|
|
|
%tmp3 = or <2 x i64> %tmp1, %tmp2
|
|
|
|
ret <2 x i64> %tmp3
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
define <8 x i8> @bsl8xi8(<8 x i8> %v1, <8 x i8> %v2, <8 x i8> %v3) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: bsl8xi8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bsl v0.8b, v1.8b, v2.8b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%1 = and <8 x i8> %v1, %v2
|
|
|
|
%2 = xor <8 x i8> %v1, <i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1>
|
|
|
|
%3 = and <8 x i8> %2, %v3
|
|
|
|
%4 = or <8 x i8> %1, %3
|
|
|
|
ret <8 x i8> %4
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i16> @bsl4xi16(<4 x i16> %v1, <4 x i16> %v2, <4 x i16> %v3) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: bsl4xi16:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bsl v0.8b, v1.8b, v2.8b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%1 = and <4 x i16> %v1, %v2
|
|
|
|
%2 = xor <4 x i16> %v1, <i16 -1, i16 -1, i16 -1, i16 -1>
|
|
|
|
%3 = and <4 x i16> %2, %v3
|
|
|
|
%4 = or <4 x i16> %1, %3
|
|
|
|
ret <4 x i16> %4
|
|
|
|
}
|
|
|
|
|
|
|
|
define <2 x i32> @bsl2xi32(<2 x i32> %v1, <2 x i32> %v2, <2 x i32> %v3) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: bsl2xi32:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bsl v0.8b, v1.8b, v2.8b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%1 = and <2 x i32> %v1, %v2
|
|
|
|
%2 = xor <2 x i32> %v1, <i32 -1, i32 -1>
|
|
|
|
%3 = and <2 x i32> %2, %v3
|
|
|
|
%4 = or <2 x i32> %1, %3
|
|
|
|
ret <2 x i32> %4
|
|
|
|
}
|
|
|
|
|
|
|
|
define <1 x i64> @bsl1xi64(<1 x i64> %v1, <1 x i64> %v2, <1 x i64> %v3) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: bsl1xi64:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bsl v0.8b, v1.8b, v2.8b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%1 = and <1 x i64> %v1, %v2
|
|
|
|
%2 = xor <1 x i64> %v1, <i64 -1>
|
|
|
|
%3 = and <1 x i64> %2, %v3
|
|
|
|
%4 = or <1 x i64> %1, %3
|
|
|
|
ret <1 x i64> %4
|
|
|
|
}
|
|
|
|
|
|
|
|
define <16 x i8> @bsl16xi8(<16 x i8> %v1, <16 x i8> %v2, <16 x i8> %v3) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: bsl16xi8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bsl v0.16b, v1.16b, v2.16b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%1 = and <16 x i8> %v1, %v2
|
|
|
|
%2 = xor <16 x i8> %v1, <i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1>
|
|
|
|
%3 = and <16 x i8> %2, %v3
|
|
|
|
%4 = or <16 x i8> %1, %3
|
|
|
|
ret <16 x i8> %4
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i16> @bsl8xi16(<8 x i16> %v1, <8 x i16> %v2, <8 x i16> %v3) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: bsl8xi16:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bsl v0.16b, v1.16b, v2.16b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%1 = and <8 x i16> %v1, %v2
|
|
|
|
%2 = xor <8 x i16> %v1, <i16 -1, i16 -1, i16 -1, i16 -1, i16 -1, i16 -1, i16 -1, i16 -1>
|
|
|
|
%3 = and <8 x i16> %2, %v3
|
|
|
|
%4 = or <8 x i16> %1, %3
|
|
|
|
ret <8 x i16> %4
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i32> @bsl4xi32(<4 x i32> %v1, <4 x i32> %v2, <4 x i32> %v3) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: bsl4xi32:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bsl v0.16b, v1.16b, v2.16b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%1 = and <4 x i32> %v1, %v2
|
|
|
|
%2 = xor <4 x i32> %v1, <i32 -1, i32 -1, i32 -1, i32 -1>
|
|
|
|
%3 = and <4 x i32> %2, %v3
|
|
|
|
%4 = or <4 x i32> %1, %3
|
|
|
|
ret <4 x i32> %4
|
|
|
|
}
|
|
|
|
|
[AArch64 NEON] Fix invalid constant used in vselect condition.
There is a wrong assumption that the vector element type and the
type of each ConstantSDNode in the build_vector were the same.
However, when promoting the integer operand of a legally typed
build_vector, the operand type and the vector element type do not
need to be the same
(See method 'DAGTypeLegalizer::PromoteIntOp_BUILD_VECTOR' in
LegalizeIntegerTypes.cpp).
in AArch64 backend, the following dag sequence:
C0: i1 = Constant<0>
C1: i1 = Constant<-1>
V: v8i1 = BUILD_VECTOR C1, C1, C0, C0, C0, C0, C0, C0
is type-legalized into:
NewC0: i32 = Constant<0>
NewC1: i32 = Constant<1>
V: v8i8 = BUILD_VECTOR NewC1, NewC1, NewC0, NewC0, NewC0, NewC0, NewC0, NewC0
Forcing a getZeroExtend to VTBits to ensure that the new constant
is correctly.
llvm-svn: 198582
2014-01-06 10:26:10 +08:00
|
|
|
define <8 x i8> @vselect_v8i8(<8 x i8> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: vselect_v8i8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: movi d1, #0x0000000000ffff
|
|
|
|
; CHECK-NEXT: and v0.8b, v0.8b, v1.8b
|
|
|
|
; CHECK-NEXT: orr v0.2s, #0
|
|
|
|
; CHECK-NEXT: ret
|
[AArch64 NEON] Fix invalid constant used in vselect condition.
There is a wrong assumption that the vector element type and the
type of each ConstantSDNode in the build_vector were the same.
However, when promoting the integer operand of a legally typed
build_vector, the operand type and the vector element type do not
need to be the same
(See method 'DAGTypeLegalizer::PromoteIntOp_BUILD_VECTOR' in
LegalizeIntegerTypes.cpp).
in AArch64 backend, the following dag sequence:
C0: i1 = Constant<0>
C1: i1 = Constant<-1>
V: v8i1 = BUILD_VECTOR C1, C1, C0, C0, C0, C0, C0, C0
is type-legalized into:
NewC0: i32 = Constant<0>
NewC1: i32 = Constant<1>
V: v8i8 = BUILD_VECTOR NewC1, NewC1, NewC0, NewC0, NewC0, NewC0, NewC0, NewC0
Forcing a getZeroExtend to VTBits to ensure that the new constant
is correctly.
llvm-svn: 198582
2014-01-06 10:26:10 +08:00
|
|
|
%b = select <8 x i1> <i1 true, i1 true, i1 false, i1 false, i1 false, i1 false, i1 false, i1 false>, <8 x i8> %a, <8 x i8> <i8 undef, i8 undef, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0>
|
|
|
|
ret <8 x i8> %b
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i16> @vselect_v4i16(<4 x i16> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: vselect_v4i16:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: movi d1, #0x0000000000ffff
|
|
|
|
; CHECK-NEXT: and v0.8b, v0.8b, v1.8b
|
|
|
|
; CHECK-NEXT: orr v0.2s, #0
|
|
|
|
; CHECK-NEXT: ret
|
[AArch64 NEON] Fix invalid constant used in vselect condition.
There is a wrong assumption that the vector element type and the
type of each ConstantSDNode in the build_vector were the same.
However, when promoting the integer operand of a legally typed
build_vector, the operand type and the vector element type do not
need to be the same
(See method 'DAGTypeLegalizer::PromoteIntOp_BUILD_VECTOR' in
LegalizeIntegerTypes.cpp).
in AArch64 backend, the following dag sequence:
C0: i1 = Constant<0>
C1: i1 = Constant<-1>
V: v8i1 = BUILD_VECTOR C1, C1, C0, C0, C0, C0, C0, C0
is type-legalized into:
NewC0: i32 = Constant<0>
NewC1: i32 = Constant<1>
V: v8i8 = BUILD_VECTOR NewC1, NewC1, NewC0, NewC0, NewC0, NewC0, NewC0, NewC0
Forcing a getZeroExtend to VTBits to ensure that the new constant
is correctly.
llvm-svn: 198582
2014-01-06 10:26:10 +08:00
|
|
|
%b = select <4 x i1> <i1 true, i1 false, i1 false, i1 false>, <4 x i16> %a, <4 x i16> <i16 undef, i16 0, i16 0, i16 0>
|
|
|
|
ret <4 x i16> %b
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i8> @vselect_cmp_ne(<8 x i8> %a, <8 x i8> %b, <8 x i8> %c) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: vselect_cmp_ne:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: cmeq v0.8b, v0.8b, v1.8b
|
|
|
|
; CHECK-NEXT: mvn v0.8b, v0.8b
|
|
|
|
; CHECK-NEXT: bsl v0.8b, v1.8b, v2.8b
|
|
|
|
; CHECK-NEXT: ret
|
[AArch64 NEON] Fix invalid constant used in vselect condition.
There is a wrong assumption that the vector element type and the
type of each ConstantSDNode in the build_vector were the same.
However, when promoting the integer operand of a legally typed
build_vector, the operand type and the vector element type do not
need to be the same
(See method 'DAGTypeLegalizer::PromoteIntOp_BUILD_VECTOR' in
LegalizeIntegerTypes.cpp).
in AArch64 backend, the following dag sequence:
C0: i1 = Constant<0>
C1: i1 = Constant<-1>
V: v8i1 = BUILD_VECTOR C1, C1, C0, C0, C0, C0, C0, C0
is type-legalized into:
NewC0: i32 = Constant<0>
NewC1: i32 = Constant<1>
V: v8i8 = BUILD_VECTOR NewC1, NewC1, NewC0, NewC0, NewC0, NewC0, NewC0, NewC0
Forcing a getZeroExtend to VTBits to ensure that the new constant
is correctly.
llvm-svn: 198582
2014-01-06 10:26:10 +08:00
|
|
|
%cmp = icmp ne <8 x i8> %a, %b
|
|
|
|
%d = select <8 x i1> %cmp, <8 x i8> %b, <8 x i8> %c
|
|
|
|
ret <8 x i8> %d
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i8> @vselect_cmp_eq(<8 x i8> %a, <8 x i8> %b, <8 x i8> %c) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: vselect_cmp_eq:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: cmeq v0.8b, v0.8b, v1.8b
|
|
|
|
; CHECK-NEXT: bsl v0.8b, v1.8b, v2.8b
|
|
|
|
; CHECK-NEXT: ret
|
[AArch64 NEON] Fix invalid constant used in vselect condition.
There is a wrong assumption that the vector element type and the
type of each ConstantSDNode in the build_vector were the same.
However, when promoting the integer operand of a legally typed
build_vector, the operand type and the vector element type do not
need to be the same
(See method 'DAGTypeLegalizer::PromoteIntOp_BUILD_VECTOR' in
LegalizeIntegerTypes.cpp).
in AArch64 backend, the following dag sequence:
C0: i1 = Constant<0>
C1: i1 = Constant<-1>
V: v8i1 = BUILD_VECTOR C1, C1, C0, C0, C0, C0, C0, C0
is type-legalized into:
NewC0: i32 = Constant<0>
NewC1: i32 = Constant<1>
V: v8i8 = BUILD_VECTOR NewC1, NewC1, NewC0, NewC0, NewC0, NewC0, NewC0, NewC0
Forcing a getZeroExtend to VTBits to ensure that the new constant
is correctly.
llvm-svn: 198582
2014-01-06 10:26:10 +08:00
|
|
|
%cmp = icmp eq <8 x i8> %a, %b
|
|
|
|
%d = select <8 x i1> %cmp, <8 x i8> %b, <8 x i8> %c
|
|
|
|
ret <8 x i8> %d
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i8> @vselect_cmpz_ne(<8 x i8> %a, <8 x i8> %b, <8 x i8> %c) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: vselect_cmpz_ne:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: cmeq v0.8b, v0.8b, #0
|
|
|
|
; CHECK-NEXT: mvn v0.8b, v0.8b
|
|
|
|
; CHECK-NEXT: bsl v0.8b, v1.8b, v2.8b
|
|
|
|
; CHECK-NEXT: ret
|
[AArch64 NEON] Fix invalid constant used in vselect condition.
There is a wrong assumption that the vector element type and the
type of each ConstantSDNode in the build_vector were the same.
However, when promoting the integer operand of a legally typed
build_vector, the operand type and the vector element type do not
need to be the same
(See method 'DAGTypeLegalizer::PromoteIntOp_BUILD_VECTOR' in
LegalizeIntegerTypes.cpp).
in AArch64 backend, the following dag sequence:
C0: i1 = Constant<0>
C1: i1 = Constant<-1>
V: v8i1 = BUILD_VECTOR C1, C1, C0, C0, C0, C0, C0, C0
is type-legalized into:
NewC0: i32 = Constant<0>
NewC1: i32 = Constant<1>
V: v8i8 = BUILD_VECTOR NewC1, NewC1, NewC0, NewC0, NewC0, NewC0, NewC0, NewC0
Forcing a getZeroExtend to VTBits to ensure that the new constant
is correctly.
llvm-svn: 198582
2014-01-06 10:26:10 +08:00
|
|
|
%cmp = icmp ne <8 x i8> %a, zeroinitializer
|
|
|
|
%d = select <8 x i1> %cmp, <8 x i8> %b, <8 x i8> %c
|
|
|
|
ret <8 x i8> %d
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i8> @vselect_cmpz_eq(<8 x i8> %a, <8 x i8> %b, <8 x i8> %c) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: vselect_cmpz_eq:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: cmeq v0.8b, v0.8b, #0
|
|
|
|
; CHECK-NEXT: bsl v0.8b, v1.8b, v2.8b
|
|
|
|
; CHECK-NEXT: ret
|
[AArch64 NEON] Fix invalid constant used in vselect condition.
There is a wrong assumption that the vector element type and the
type of each ConstantSDNode in the build_vector were the same.
However, when promoting the integer operand of a legally typed
build_vector, the operand type and the vector element type do not
need to be the same
(See method 'DAGTypeLegalizer::PromoteIntOp_BUILD_VECTOR' in
LegalizeIntegerTypes.cpp).
in AArch64 backend, the following dag sequence:
C0: i1 = Constant<0>
C1: i1 = Constant<-1>
V: v8i1 = BUILD_VECTOR C1, C1, C0, C0, C0, C0, C0, C0
is type-legalized into:
NewC0: i32 = Constant<0>
NewC1: i32 = Constant<1>
V: v8i8 = BUILD_VECTOR NewC1, NewC1, NewC0, NewC0, NewC0, NewC0, NewC0, NewC0
Forcing a getZeroExtend to VTBits to ensure that the new constant
is correctly.
llvm-svn: 198582
2014-01-06 10:26:10 +08:00
|
|
|
%cmp = icmp eq <8 x i8> %a, zeroinitializer
|
|
|
|
%d = select <8 x i1> %cmp, <8 x i8> %b, <8 x i8> %c
|
|
|
|
ret <8 x i8> %d
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i8> @vselect_tst(<8 x i8> %a, <8 x i8> %b, <8 x i8> %c) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: vselect_tst:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: cmtst v0.8b, v0.8b, v1.8b
|
|
|
|
; CHECK-NEXT: bsl v0.8b, v1.8b, v2.8b
|
|
|
|
; CHECK-NEXT: ret
|
[AArch64 NEON] Fix invalid constant used in vselect condition.
There is a wrong assumption that the vector element type and the
type of each ConstantSDNode in the build_vector were the same.
However, when promoting the integer operand of a legally typed
build_vector, the operand type and the vector element type do not
need to be the same
(See method 'DAGTypeLegalizer::PromoteIntOp_BUILD_VECTOR' in
LegalizeIntegerTypes.cpp).
in AArch64 backend, the following dag sequence:
C0: i1 = Constant<0>
C1: i1 = Constant<-1>
V: v8i1 = BUILD_VECTOR C1, C1, C0, C0, C0, C0, C0, C0
is type-legalized into:
NewC0: i32 = Constant<0>
NewC1: i32 = Constant<1>
V: v8i8 = BUILD_VECTOR NewC1, NewC1, NewC0, NewC0, NewC0, NewC0, NewC0, NewC0
Forcing a getZeroExtend to VTBits to ensure that the new constant
is correctly.
llvm-svn: 198582
2014-01-06 10:26:10 +08:00
|
|
|
%tmp3 = and <8 x i8> %a, %b
|
|
|
|
%tmp4 = icmp ne <8 x i8> %tmp3, zeroinitializer
|
|
|
|
%d = select <8 x i1> %tmp4, <8 x i8> %b, <8 x i8> %c
|
|
|
|
ret <8 x i8> %d
|
|
|
|
}
|
|
|
|
|
2013-08-01 17:20:35 +08:00
|
|
|
define <2 x i64> @bsl2xi64(<2 x i64> %v1, <2 x i64> %v2, <2 x i64> %v3) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: bsl2xi64:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bsl v0.16b, v1.16b, v2.16b
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%1 = and <2 x i64> %v1, %v2
|
|
|
|
%2 = xor <2 x i64> %v1, <i64 -1, i64 -1>
|
|
|
|
%3 = and <2 x i64> %2, %v3
|
|
|
|
%4 = or <2 x i64> %1, %3
|
|
|
|
ret <2 x i64> %4
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i8> @orrimm8b_as_orrimm4h_lsl0(<8 x i8> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orrimm8b_as_orrimm4h_lsl0:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.4h, #255
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%val = or <8 x i8> %a, <i8 255, i8 0, i8 255, i8 0, i8 255, i8 0, i8 255, i8 0>
|
|
|
|
ret <8 x i8> %val
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i8> @orrimm8b_as_orimm4h_lsl8(<8 x i8> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orrimm8b_as_orimm4h_lsl8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.4h, #255, lsl #8
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%val = or <8 x i8> %a, <i8 0, i8 255, i8 0, i8 255, i8 0, i8 255, i8 0, i8 255>
|
|
|
|
ret <8 x i8> %val
|
|
|
|
}
|
|
|
|
|
|
|
|
define <16 x i8> @orimm16b_as_orrimm8h_lsl0(<16 x i8> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orimm16b_as_orrimm8h_lsl0:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.8h, #255
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%val = or <16 x i8> %a, <i8 255, i8 0, i8 255, i8 0, i8 255, i8 0, i8 255, i8 0, i8 255, i8 0, i8 255, i8 0, i8 255, i8 0, i8 255, i8 0>
|
|
|
|
ret <16 x i8> %val
|
|
|
|
}
|
|
|
|
|
|
|
|
define <16 x i8> @orimm16b_as_orrimm8h_lsl8(<16 x i8> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orimm16b_as_orrimm8h_lsl8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.8h, #255, lsl #8
|
|
|
|
; CHECK-NEXT: ret
|
2013-08-01 17:20:35 +08:00
|
|
|
%val = or <16 x i8> %a, <i8 0, i8 255, i8 0, i8 255, i8 0, i8 255, i8 0, i8 255, i8 0, i8 255, i8 0, i8 255, i8 0, i8 255, i8 0, i8 255>
|
|
|
|
ret <16 x i8> %val
|
|
|
|
}
|
|
|
|
|
2014-01-07 13:10:47 +08:00
|
|
|
define <8 x i8> @and8imm2s_lsl0(<8 x i8> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and8imm2s_lsl0:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.2s, #255
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <8 x i8> %a, < i8 0, i8 255, i8 255, i8 255, i8 0, i8 255, i8 255, i8 255>
|
|
|
|
ret <8 x i8> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i8> @and8imm2s_lsl8(<8 x i8> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and8imm2s_lsl8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.2s, #255, lsl #8
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <8 x i8> %a, < i8 255, i8 0, i8 255, i8 255, i8 255, i8 0, i8 255, i8 255>
|
|
|
|
ret <8 x i8> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i8> @and8imm2s_lsl16(<8 x i8> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and8imm2s_lsl16:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.2s, #255, lsl #16
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <8 x i8> %a, < i8 255, i8 255, i8 0, i8 255, i8 255, i8 255, i8 0, i8 255>
|
|
|
|
ret <8 x i8> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i8> @and8imm2s_lsl24(<8 x i8> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and8imm2s_lsl24:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.2s, #254, lsl #24
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <8 x i8> %a, < i8 255, i8 255, i8 255, i8 1, i8 255, i8 255, i8 255, i8 1>
|
|
|
|
ret <8 x i8> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i16> @and16imm2s_lsl0(<4 x i16> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and16imm2s_lsl0:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.2s, #255
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <4 x i16> %a, < i16 65280, i16 65535, i16 65280, i16 65535>
|
|
|
|
ret <4 x i16> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i16> @and16imm2s_lsl8(<4 x i16> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and16imm2s_lsl8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.2s, #255, lsl #8
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <4 x i16> %a, < i16 255, i16 65535, i16 255, i16 65535>
|
|
|
|
ret <4 x i16> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i16> @and16imm2s_lsl16(<4 x i16> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and16imm2s_lsl16:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.2s, #255, lsl #16
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <4 x i16> %a, < i16 65535, i16 65280, i16 65535, i16 65280>
|
|
|
|
ret <4 x i16> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i16> @and16imm2s_lsl24(<4 x i16> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and16imm2s_lsl24:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.2s, #254, lsl #24
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <4 x i16> %a, < i16 65535, i16 511, i16 65535, i16 511>
|
|
|
|
ret <4 x i16> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
define <1 x i64> @and64imm2s_lsl0(<1 x i64> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and64imm2s_lsl0:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.2s, #255
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <1 x i64> %a, < i64 -1095216660736>
|
|
|
|
ret <1 x i64> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <1 x i64> @and64imm2s_lsl8(<1 x i64> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and64imm2s_lsl8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.2s, #255, lsl #8
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <1 x i64> %a, < i64 -280375465148161>
|
|
|
|
ret <1 x i64> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <1 x i64> @and64imm2s_lsl16(<1 x i64> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and64imm2s_lsl16:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.2s, #255, lsl #16
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <1 x i64> %a, < i64 -71776119077928961>
|
|
|
|
ret <1 x i64> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <1 x i64> @and64imm2s_lsl24(<1 x i64> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and64imm2s_lsl24:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.2s, #254, lsl #24
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <1 x i64> %a, < i64 144115183814443007>
|
|
|
|
ret <1 x i64> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <16 x i8> @and8imm4s_lsl0(<16 x i8> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and8imm4s_lsl0:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.4s, #255
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <16 x i8> %a, < i8 0, i8 255, i8 255, i8 255, i8 0, i8 255, i8 255, i8 255, i8 0, i8 255, i8 255, i8 255, i8 0, i8 255, i8 255, i8 255>
|
|
|
|
ret <16 x i8> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <16 x i8> @and8imm4s_lsl8(<16 x i8> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and8imm4s_lsl8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.4s, #255, lsl #8
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <16 x i8> %a, < i8 255, i8 0, i8 255, i8 255, i8 255, i8 0, i8 255, i8 255, i8 255, i8 0, i8 255, i8 255, i8 255, i8 0, i8 255, i8 255>
|
|
|
|
ret <16 x i8> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <16 x i8> @and8imm4s_lsl16(<16 x i8> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and8imm4s_lsl16:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.4s, #255, lsl #16
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <16 x i8> %a, < i8 255, i8 255, i8 0, i8 255, i8 255, i8 255, i8 0, i8 255, i8 255, i8 255, i8 0, i8 255, i8 255, i8 255, i8 0, i8 255>
|
|
|
|
ret <16 x i8> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <16 x i8> @and8imm4s_lsl24(<16 x i8> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and8imm4s_lsl24:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.4s, #254, lsl #24
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <16 x i8> %a, < i8 255, i8 255, i8 255, i8 1, i8 255, i8 255, i8 255, i8 1, i8 255, i8 255, i8 255, i8 1, i8 255, i8 255, i8 255, i8 1>
|
|
|
|
ret <16 x i8> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i16> @and16imm4s_lsl0(<8 x i16> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and16imm4s_lsl0:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.4s, #255
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <8 x i16> %a, < i16 65280, i16 65535, i16 65280, i16 65535, i16 65280, i16 65535, i16 65280, i16 65535>
|
|
|
|
ret <8 x i16> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i16> @and16imm4s_lsl8(<8 x i16> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and16imm4s_lsl8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.4s, #255, lsl #8
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <8 x i16> %a, < i16 255, i16 65535, i16 255, i16 65535, i16 255, i16 65535, i16 255, i16 65535>
|
|
|
|
ret <8 x i16> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i16> @and16imm4s_lsl16(<8 x i16> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and16imm4s_lsl16:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.4s, #255, lsl #16
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <8 x i16> %a, < i16 65535, i16 65280, i16 65535, i16 65280, i16 65535, i16 65280, i16 65535, i16 65280>
|
|
|
|
ret <8 x i16> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i16> @and16imm4s_lsl24(<8 x i16> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and16imm4s_lsl24:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.4s, #254, lsl #24
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <8 x i16> %a, < i16 65535, i16 511, i16 65535, i16 511, i16 65535, i16 511, i16 65535, i16 511>
|
|
|
|
ret <8 x i16> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <2 x i64> @and64imm4s_lsl0(<2 x i64> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and64imm4s_lsl0:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.4s, #255
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <2 x i64> %a, < i64 -1095216660736, i64 -1095216660736>
|
|
|
|
ret <2 x i64> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <2 x i64> @and64imm4s_lsl8(<2 x i64> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and64imm4s_lsl8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.4s, #255, lsl #8
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <2 x i64> %a, < i64 -280375465148161, i64 -280375465148161>
|
|
|
|
ret <2 x i64> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <2 x i64> @and64imm4s_lsl16(<2 x i64> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and64imm4s_lsl16:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.4s, #255, lsl #16
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <2 x i64> %a, < i64 -71776119077928961, i64 -71776119077928961>
|
|
|
|
ret <2 x i64> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <2 x i64> @and64imm4s_lsl24(<2 x i64> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and64imm4s_lsl24:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.4s, #254, lsl #24
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <2 x i64> %a, < i64 144115183814443007, i64 144115183814443007>
|
|
|
|
ret <2 x i64> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i8> @and8imm4h_lsl0(<8 x i8> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and8imm4h_lsl0:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.4h, #255
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <8 x i8> %a, < i8 0, i8 255, i8 0, i8 255, i8 0, i8 255, i8 0, i8 255>
|
|
|
|
ret <8 x i8> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i8> @and8imm4h_lsl8(<8 x i8> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and8imm4h_lsl8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.4h, #255, lsl #8
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <8 x i8> %a, < i8 255, i8 0, i8 255, i8 0, i8 255, i8 0, i8 255, i8 0>
|
|
|
|
ret <8 x i8> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <2 x i32> @and16imm4h_lsl0(<2 x i32> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and16imm4h_lsl0:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.4h, #255
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <2 x i32> %a, < i32 4278255360, i32 4278255360>
|
|
|
|
ret <2 x i32> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <2 x i32> @and16imm4h_lsl8(<2 x i32> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and16imm4h_lsl8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.4h, #255, lsl #8
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <2 x i32> %a, < i32 16711935, i32 16711935>
|
|
|
|
ret <2 x i32> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <1 x i64> @and64imm4h_lsl0(<1 x i64> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and64imm4h_lsl0:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.4h, #255
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <1 x i64> %a, < i64 -71777214294589696>
|
|
|
|
ret <1 x i64> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <1 x i64> @and64imm4h_lsl8(<1 x i64> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and64imm4h_lsl8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.4h, #255, lsl #8
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <1 x i64> %a, < i64 71777214294589695>
|
|
|
|
ret <1 x i64> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <16 x i8> @and8imm8h_lsl0(<16 x i8> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and8imm8h_lsl0:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.8h, #255
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <16 x i8> %a, < i8 0, i8 255, i8 0, i8 255, i8 0, i8 255, i8 0, i8 255, i8 0, i8 255, i8 0, i8 255, i8 0, i8 255, i8 0, i8 255 >
|
|
|
|
ret <16 x i8> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <16 x i8> @and8imm8h_lsl8(<16 x i8> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and8imm8h_lsl8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.8h, #255, lsl #8
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <16 x i8> %a, <i8 255, i8 0, i8 255, i8 0, i8 255, i8 0, i8 255, i8 0, i8 255, i8 0, i8 255, i8 0, i8 255, i8 0, i8 255, i8 0 >
|
|
|
|
ret <16 x i8> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i32> @and16imm8h_lsl0(<4 x i32> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and16imm8h_lsl0:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.8h, #255
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <4 x i32> %a, < i32 4278255360, i32 4278255360, i32 4278255360, i32 4278255360>
|
|
|
|
ret <4 x i32> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i32> @and16imm8h_lsl8(<4 x i32> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and16imm8h_lsl8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.8h, #255, lsl #8
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <4 x i32> %a, < i32 16711935, i32 16711935, i32 16711935, i32 16711935>
|
|
|
|
ret <4 x i32> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <2 x i64> @and64imm8h_lsl0(<2 x i64> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and64imm8h_lsl0:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.8h, #255
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <2 x i64> %a, < i64 -71777214294589696, i64 -71777214294589696>
|
|
|
|
ret <2 x i64> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <2 x i64> @and64imm8h_lsl8(<2 x i64> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: and64imm8h_lsl8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: bic v0.8h, #255, lsl #8
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = and <2 x i64> %a, < i64 71777214294589695, i64 71777214294589695>
|
|
|
|
ret <2 x i64> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i8> @orr8imm2s_lsl0(<8 x i8> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr8imm2s_lsl0:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.2s, #255
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = or <8 x i8> %a, < i8 255, i8 0, i8 0, i8 0, i8 255, i8 0, i8 0, i8 0>
|
|
|
|
ret <8 x i8> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i8> @orr8imm2s_lsl8(<8 x i8> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr8imm2s_lsl8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.2s, #255, lsl #8
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = or <8 x i8> %a, < i8 0, i8 255, i8 0, i8 0, i8 0, i8 255, i8 0, i8 0>
|
|
|
|
ret <8 x i8> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i8> @orr8imm2s_lsl16(<8 x i8> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr8imm2s_lsl16:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.2s, #255, lsl #16
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = or <8 x i8> %a, < i8 0, i8 0, i8 255, i8 0, i8 0, i8 0, i8 255, i8 0>
|
|
|
|
ret <8 x i8> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i8> @orr8imm2s_lsl24(<8 x i8> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr8imm2s_lsl24:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.2s, #255, lsl #24
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = or <8 x i8> %a, < i8 0, i8 0, i8 0, i8 255, i8 0, i8 0, i8 0, i8 255>
|
|
|
|
ret <8 x i8> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i16> @orr16imm2s_lsl0(<4 x i16> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr16imm2s_lsl0:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.2s, #255
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = or <4 x i16> %a, < i16 255, i16 0, i16 255, i16 0>
|
|
|
|
ret <4 x i16> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i16> @orr16imm2s_lsl8(<4 x i16> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr16imm2s_lsl8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.2s, #255, lsl #8
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = or <4 x i16> %a, < i16 65280, i16 0, i16 65280, i16 0>
|
|
|
|
ret <4 x i16> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i16> @orr16imm2s_lsl16(<4 x i16> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr16imm2s_lsl16:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.2s, #255, lsl #16
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = or <4 x i16> %a, < i16 0, i16 255, i16 0, i16 255>
|
|
|
|
ret <4 x i16> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i16> @orr16imm2s_lsl24(<4 x i16> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr16imm2s_lsl24:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.2s, #255, lsl #24
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = or <4 x i16> %a, < i16 0, i16 65280, i16 0, i16 65280>
|
|
|
|
ret <4 x i16> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <1 x i64> @orr64imm2s_lsl0(<1 x i64> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr64imm2s_lsl0:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.2s, #255
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = or <1 x i64> %a, < i64 1095216660735>
|
|
|
|
ret <1 x i64> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <1 x i64> @orr64imm2s_lsl8(<1 x i64> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr64imm2s_lsl8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.2s, #255, lsl #8
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = or <1 x i64> %a, < i64 280375465148160>
|
|
|
|
ret <1 x i64> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <1 x i64> @orr64imm2s_lsl16(<1 x i64> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr64imm2s_lsl16:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.2s, #255, lsl #16
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = or <1 x i64> %a, < i64 71776119077928960>
|
|
|
|
ret <1 x i64> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <1 x i64> @orr64imm2s_lsl24(<1 x i64> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr64imm2s_lsl24:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.2s, #255, lsl #24
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = or <1 x i64> %a, < i64 -72057589759737856>
|
|
|
|
ret <1 x i64> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <16 x i8> @orr8imm4s_lsl0(<16 x i8> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr8imm4s_lsl0:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.4s, #255
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = or <16 x i8> %a, < i8 255, i8 0, i8 0, i8 0, i8 255, i8 0, i8 0, i8 0, i8 255, i8 0, i8 0, i8 0, i8 255, i8 0, i8 0, i8 0>
|
|
|
|
ret <16 x i8> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <16 x i8> @orr8imm4s_lsl8(<16 x i8> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr8imm4s_lsl8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.4s, #255, lsl #8
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = or <16 x i8> %a, < i8 0, i8 255, i8 0, i8 0, i8 0, i8 255, i8 0, i8 0, i8 0, i8 255, i8 0, i8 0, i8 0, i8 255, i8 0, i8 0>
|
|
|
|
ret <16 x i8> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <16 x i8> @orr8imm4s_lsl16(<16 x i8> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr8imm4s_lsl16:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.4s, #255, lsl #16
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = or <16 x i8> %a, < i8 0, i8 0, i8 255, i8 0, i8 0, i8 0, i8 255, i8 0, i8 0, i8 0, i8 255, i8 0, i8 0, i8 0, i8 255, i8 0>
|
|
|
|
ret <16 x i8> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <16 x i8> @orr8imm4s_lsl24(<16 x i8> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr8imm4s_lsl24:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.4s, #255, lsl #24
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = or <16 x i8> %a, < i8 0, i8 0, i8 0, i8 255, i8 0, i8 0, i8 0, i8 255, i8 0, i8 0, i8 0, i8 255, i8 0, i8 0, i8 0, i8 255>
|
|
|
|
ret <16 x i8> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i16> @orr16imm4s_lsl0(<8 x i16> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr16imm4s_lsl0:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.4s, #255
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = or <8 x i16> %a, < i16 255, i16 0, i16 255, i16 0, i16 255, i16 0, i16 255, i16 0>
|
|
|
|
ret <8 x i16> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i16> @orr16imm4s_lsl8(<8 x i16> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr16imm4s_lsl8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.4s, #255, lsl #8
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = or <8 x i16> %a, < i16 65280, i16 0, i16 65280, i16 0, i16 65280, i16 0, i16 65280, i16 0>
|
|
|
|
ret <8 x i16> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i16> @orr16imm4s_lsl16(<8 x i16> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr16imm4s_lsl16:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.4s, #255, lsl #16
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = or <8 x i16> %a, < i16 0, i16 255, i16 0, i16 255, i16 0, i16 255, i16 0, i16 255>
|
|
|
|
ret <8 x i16> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i16> @orr16imm4s_lsl24(<8 x i16> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr16imm4s_lsl24:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.4s, #255, lsl #24
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = or <8 x i16> %a, < i16 0, i16 65280, i16 0, i16 65280, i16 0, i16 65280, i16 0, i16 65280>
|
|
|
|
ret <8 x i16> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <2 x i64> @orr64imm4s_lsl0(<2 x i64> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr64imm4s_lsl0:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.4s, #255
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = or <2 x i64> %a, < i64 1095216660735, i64 1095216660735>
|
|
|
|
ret <2 x i64> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <2 x i64> @orr64imm4s_lsl8(<2 x i64> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr64imm4s_lsl8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.4s, #255, lsl #8
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = or <2 x i64> %a, < i64 280375465148160, i64 280375465148160>
|
|
|
|
ret <2 x i64> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <2 x i64> @orr64imm4s_lsl16(<2 x i64> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr64imm4s_lsl16:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.4s, #255, lsl #16
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = or <2 x i64> %a, < i64 71776119077928960, i64 71776119077928960>
|
|
|
|
ret <2 x i64> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <2 x i64> @orr64imm4s_lsl24(<2 x i64> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr64imm4s_lsl24:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.4s, #255, lsl #24
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = or <2 x i64> %a, < i64 -72057589759737856, i64 -72057589759737856>
|
|
|
|
ret <2 x i64> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i8> @orr8imm4h_lsl0(<8 x i8> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr8imm4h_lsl0:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.4h, #255
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = or <8 x i8> %a, < i8 255, i8 0, i8 255, i8 0, i8 255, i8 0, i8 255, i8 0>
|
|
|
|
ret <8 x i8> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <8 x i8> @orr8imm4h_lsl8(<8 x i8> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr8imm4h_lsl8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.4h, #255, lsl #8
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = or <8 x i8> %a, < i8 0, i8 255, i8 0, i8 255, i8 0, i8 255, i8 0, i8 255>
|
|
|
|
ret <8 x i8> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <2 x i32> @orr16imm4h_lsl0(<2 x i32> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr16imm4h_lsl0:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.4h, #255
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = or <2 x i32> %a, < i32 16711935, i32 16711935>
|
|
|
|
ret <2 x i32> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <2 x i32> @orr16imm4h_lsl8(<2 x i32> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr16imm4h_lsl8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.4h, #255, lsl #8
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = or <2 x i32> %a, < i32 4278255360, i32 4278255360>
|
|
|
|
ret <2 x i32> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <1 x i64> @orr64imm4h_lsl0(<1 x i64> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr64imm4h_lsl0:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.4h, #255
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = or <1 x i64> %a, < i64 71777214294589695>
|
|
|
|
ret <1 x i64> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <1 x i64> @orr64imm4h_lsl8(<1 x i64> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr64imm4h_lsl8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.4h, #255, lsl #8
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = or <1 x i64> %a, < i64 -71777214294589696>
|
|
|
|
ret <1 x i64> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <16 x i8> @orr8imm8h_lsl0(<16 x i8> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr8imm8h_lsl0:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.8h, #255
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = or <16 x i8> %a, < i8 255, i8 0, i8 255, i8 0, i8 255, i8 0, i8 255, i8 0, i8 255, i8 0, i8 255, i8 0, i8 255, i8 0, i8 255, i8 0>
|
|
|
|
ret <16 x i8> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <16 x i8> @orr8imm8h_lsl8(<16 x i8> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr8imm8h_lsl8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.8h, #255, lsl #8
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = or <16 x i8> %a, < i8 0, i8 255, i8 0, i8 255, i8 0, i8 255, i8 0, i8 255, i8 0, i8 255, i8 0, i8 255, i8 0, i8 255, i8 0, i8 255>
|
|
|
|
ret <16 x i8> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i32> @orr16imm8h_lsl0(<4 x i32> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr16imm8h_lsl0:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.8h, #255
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = or <4 x i32> %a, < i32 16711935, i32 16711935, i32 16711935, i32 16711935>
|
|
|
|
ret <4 x i32> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <4 x i32> @orr16imm8h_lsl8(<4 x i32> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr16imm8h_lsl8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.8h, #255, lsl #8
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = or <4 x i32> %a, < i32 4278255360, i32 4278255360, i32 4278255360, i32 4278255360>
|
|
|
|
ret <4 x i32> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <2 x i64> @orr64imm8h_lsl0(<2 x i64> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr64imm8h_lsl0:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.8h, #255
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = or <2 x i64> %a, < i64 71777214294589695, i64 71777214294589695>
|
|
|
|
ret <2 x i64> %tmp1
|
|
|
|
}
|
|
|
|
|
|
|
|
define <2 x i64> @orr64imm8h_lsl8(<2 x i64> %a) {
|
2014-04-18 17:31:01 +08:00
|
|
|
; CHECK-LABEL: orr64imm8h_lsl8:
|
2020-02-13 02:31:18 +08:00
|
|
|
; CHECK: // %bb.0:
|
|
|
|
; CHECK-NEXT: orr v0.8h, #255, lsl #8
|
|
|
|
; CHECK-NEXT: ret
|
2014-01-07 13:10:47 +08:00
|
|
|
%tmp1 = or <2 x i64> %a, < i64 -71777214294589696, i64 -71777214294589696>
|
|
|
|
ret <2 x i64> %tmp1
|
|
|
|
}
|
2013-08-01 17:20:35 +08:00
|
|
|
|