blob: 44a3865990bbfcce9eb4ef2b05348632cce6325b [file] [log] [blame] [edit]
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 6
; RUN: llc -mtriple=aarch64 -mattr=+neon < %s | FileCheck %s --check-prefixes=COMMON,NEON
; RUN: llc -mtriple=aarch64 -mattr=+neon,+sve < %s | FileCheck %s --check-prefixes=COMMON,SVE
define <2 x i64> @movi_1_v2i64() {
; NEON-LABEL: movi_1_v2i64:
; NEON: // %bb.0:
; NEON-NEXT: mov w8, #1 // =0x1
; NEON-NEXT: dup v0.2d, x8
; NEON-NEXT: ret
;
; SVE-LABEL: movi_1_v2i64:
; SVE: // %bb.0:
; SVE-NEXT: mov z0.d, #1 // =0x1
; SVE-NEXT: ret
ret <2 x i64> splat (i64 1)
}
define <2 x i64> @movi_127_v2i64() {
; NEON-LABEL: movi_127_v2i64:
; NEON: // %bb.0:
; NEON-NEXT: mov w8, #127 // =0x7f
; NEON-NEXT: dup v0.2d, x8
; NEON-NEXT: ret
;
; SVE-LABEL: movi_127_v2i64:
; SVE: // %bb.0:
; SVE-NEXT: mov z0.d, #127 // =0x7f
; SVE-NEXT: ret
ret <2 x i64> splat (i64 127)
}
define <2 x i64> @movi_m128_v2i64() {
; NEON-LABEL: movi_m128_v2i64:
; NEON: // %bb.0:
; NEON-NEXT: mov x8, #-128 // =0xffffffffffffff80
; NEON-NEXT: dup v0.2d, x8
; NEON-NEXT: ret
;
; SVE-LABEL: movi_m128_v2i64:
; SVE: // %bb.0:
; SVE-NEXT: mov z0.d, #-128 // =0xffffffffffffff80
; SVE-NEXT: ret
ret <2 x i64> splat (i64 -128)
}
define <2 x i64> @movi_256_v2i64() {
; NEON-LABEL: movi_256_v2i64:
; NEON: // %bb.0:
; NEON-NEXT: mov w8, #256 // =0x100
; NEON-NEXT: dup v0.2d, x8
; NEON-NEXT: ret
;
; SVE-LABEL: movi_256_v2i64:
; SVE: // %bb.0:
; SVE-NEXT: mov z0.d, #256 // =0x100
; SVE-NEXT: ret
ret <2 x i64> splat (i64 256)
}
define <2 x i64> @movi_32512_v2i64() {
; NEON-LABEL: movi_32512_v2i64:
; NEON: // %bb.0:
; NEON-NEXT: mov w8, #32512 // =0x7f00
; NEON-NEXT: dup v0.2d, x8
; NEON-NEXT: ret
;
; SVE-LABEL: movi_32512_v2i64:
; SVE: // %bb.0:
; SVE-NEXT: mov z0.d, #32512 // =0x7f00
; SVE-NEXT: ret
ret <2 x i64> splat (i64 32512)
}
define <2 x i64> @movi_m32768_v2i64() {
; NEON-LABEL: movi_m32768_v2i64:
; NEON: // %bb.0:
; NEON-NEXT: mov x8, #-32768 // =0xffffffffffff8000
; NEON-NEXT: dup v0.2d, x8
; NEON-NEXT: ret
;
; SVE-LABEL: movi_m32768_v2i64:
; SVE: // %bb.0:
; SVE-NEXT: mov z0.d, #-32768 // =0xffffffffffff8000
; SVE-NEXT: ret
ret <2 x i64> splat (i64 -32768)
}
; Special cases where the destination vector does not have 64-bit elements
define <4 x i32> @movi_v4i32_1() {
; NEON-LABEL: movi_v4i32_1:
; NEON: // %bb.0:
; NEON-NEXT: adrp x8, .LCPI6_0
; NEON-NEXT: ldr q0, [x8, :lo12:.LCPI6_0]
; NEON-NEXT: ret
;
; SVE-LABEL: movi_v4i32_1:
; SVE: // %bb.0:
; SVE-NEXT: mov z0.d, #127 // =0x7f
; SVE-NEXT: ret
ret <4 x i32> <i32 127, i32 0, i32 127, i32 0>
}
define <4 x i32> @movi_v4i32_2() {
; NEON-LABEL: movi_v4i32_2:
; NEON: // %bb.0:
; NEON-NEXT: adrp x8, .LCPI7_0
; NEON-NEXT: ldr q0, [x8, :lo12:.LCPI7_0]
; NEON-NEXT: ret
;
; SVE-LABEL: movi_v4i32_2:
; SVE: // %bb.0:
; SVE-NEXT: mov z0.d, #32512 // =0x7f00
; SVE-NEXT: ret
ret <4 x i32> <i32 32512, i32 0, i32 32512, i32 0>
}
define <4 x i32> @movi_v4i32_4092() {
; NEON-LABEL: movi_v4i32_4092:
; NEON: // %bb.0:
; NEON-NEXT: mov w8, #4092 // =0xffc
; NEON-NEXT: dup v0.4s, w8
; NEON-NEXT: ret
;
; SVE-LABEL: movi_v4i32_4092:
; SVE: // %bb.0:
; SVE-NEXT: mov z0.s, #4092 // =0xffc
; SVE-NEXT: ret
ret <4 x i32> splat (i32 4092)
}
define <8 x i16> @movi_v8i16_1() {
; NEON-LABEL: movi_v8i16_1:
; NEON: // %bb.0:
; NEON-NEXT: adrp x8, .LCPI9_0
; NEON-NEXT: ldr q0, [x8, :lo12:.LCPI9_0]
; NEON-NEXT: ret
;
; SVE-LABEL: movi_v8i16_1:
; SVE: // %bb.0:
; SVE-NEXT: mov z0.d, #127 // =0x7f
; SVE-NEXT: ret
ret <8 x i16> <i16 127, i16 0, i16 0, i16 0, i16 127, i16 0, i16 0, i16 0>
}
define <8 x i16> @movi_v8i16_2() {
; NEON-LABEL: movi_v8i16_2:
; NEON: // %bb.0:
; NEON-NEXT: adrp x8, .LCPI10_0
; NEON-NEXT: ldr q0, [x8, :lo12:.LCPI10_0]
; NEON-NEXT: ret
;
; SVE-LABEL: movi_v8i16_2:
; SVE: // %bb.0:
; SVE-NEXT: mov z0.d, #32512 // =0x7f00
; SVE-NEXT: ret
ret <8 x i16> <i16 32512, i16 0, i16 0, i16 0, i16 32512, i16 0, i16 0, i16 0>
}
define <8 x i16> @movi_v8i16_510() {
; NEON-LABEL: movi_v8i16_510:
; NEON: // %bb.0:
; NEON-NEXT: mov w8, #510 // =0x1fe
; NEON-NEXT: dup v0.8h, w8
; NEON-NEXT: ret
;
; SVE-LABEL: movi_v8i16_510:
; SVE: // %bb.0:
; SVE-NEXT: mov z0.h, #510 // =0x1fe
; SVE-NEXT: ret
ret <8 x i16> splat (i16 510)
}
define <16 x i8> @movi_v16i8_1() {
; NEON-LABEL: movi_v16i8_1:
; NEON: // %bb.0:
; NEON-NEXT: adrp x8, .LCPI12_0
; NEON-NEXT: ldr q0, [x8, :lo12:.LCPI12_0]
; NEON-NEXT: ret
;
; SVE-LABEL: movi_v16i8_1:
; SVE: // %bb.0:
; SVE-NEXT: mov z0.d, #127 // =0x7f
; SVE-NEXT: ret
ret <16 x i8> <i8 127, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 127, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0>
}
define <16 x i8> @movi_v16i8_2() {
; NEON-LABEL: movi_v16i8_2:
; NEON: // %bb.0:
; NEON-NEXT: adrp x8, .LCPI13_0
; NEON-NEXT: ldr q0, [x8, :lo12:.LCPI13_0]
; NEON-NEXT: ret
;
; SVE-LABEL: movi_v16i8_2:
; SVE: // %bb.0:
; SVE-NEXT: mov z0.d, #32512 // =0x7f00
; SVE-NEXT: ret
ret <16 x i8> <i8 0, i8 127, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 127, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0>
}
; Negative cases
define <2 x i64> @movi_128_v2i64() {
; NEON-LABEL: movi_128_v2i64:
; NEON: // %bb.0:
; NEON-NEXT: mov w8, #128 // =0x80
; NEON-NEXT: dup v0.2d, x8
; NEON-NEXT: ret
;
; SVE-LABEL: movi_128_v2i64:
; SVE: // %bb.0:
; SVE-NEXT: mov z0.d, #128 // =0x80
; SVE-NEXT: ret
ret <2 x i64> splat (i64 128)
}
define <2 x i64> @movi_m127_v2i64() {
; NEON-LABEL: movi_m127_v2i64:
; NEON: // %bb.0:
; NEON-NEXT: mov x8, #-129 // =0xffffffffffffff7f
; NEON-NEXT: dup v0.2d, x8
; NEON-NEXT: ret
;
; SVE-LABEL: movi_m127_v2i64:
; SVE: // %bb.0:
; SVE-NEXT: mov z0.d, #-129 // =0xffffffffffffff7f
; SVE-NEXT: ret
ret <2 x i64> splat (i64 -129)
}
define <2 x i64> @movi_32513_v2i64() {
; COMMON-LABEL: movi_32513_v2i64:
; COMMON: // %bb.0:
; COMMON-NEXT: mov w8, #32513 // =0x7f01
; COMMON-NEXT: dup v0.2d, x8
; COMMON-NEXT: ret
ret <2 x i64> splat (i64 32513)
}
define <2 x i64> @movi_m32769_v2i64() {
; NEON-LABEL: movi_m32769_v2i64:
; NEON: // %bb.0:
; NEON-NEXT: mov x8, #-32769 // =0xffffffffffff7fff
; NEON-NEXT: dup v0.2d, x8
; NEON-NEXT: ret
;
; SVE-LABEL: movi_m32769_v2i64:
; SVE: // %bb.0:
; SVE-NEXT: mov z0.d, #0xffffffffffff7fff
; SVE-NEXT: ret
ret <2 x i64> splat (i64 -32769)
}
define <2 x i64> @movi_257_v2i64() {
; COMMON-LABEL: movi_257_v2i64:
; COMMON: // %bb.0:
; COMMON-NEXT: mov w8, #257 // =0x101
; COMMON-NEXT: dup v0.2d, x8
; COMMON-NEXT: ret
ret <2 x i64> splat (i64 257)
}
define <4 x i32> @movi_v4i32_3() {
; NEON-LABEL: movi_v4i32_3:
; NEON: // %bb.0:
; NEON-NEXT: adrp x8, .LCPI19_0
; NEON-NEXT: ldr q0, [x8, :lo12:.LCPI19_0]
; NEON-NEXT: ret
;
; SVE-LABEL: movi_v4i32_3:
; SVE: // %bb.0:
; SVE-NEXT: mov z0.d, #0xffffff80
; SVE-NEXT: ret
ret <4 x i32> <i32 -128, i32 0, i32 -128, i32 0>
}
define <16 x i8> @movi_v16i8_3() {
; NEON-LABEL: movi_v16i8_3:
; NEON: // %bb.0:
; NEON-NEXT: adrp x8, .LCPI20_0
; NEON-NEXT: ldr q0, [x8, :lo12:.LCPI20_0]
; NEON-NEXT: ret
;
; SVE-LABEL: movi_v16i8_3:
; SVE: // %bb.0:
; SVE-NEXT: mov z0.d, #0x7f0000
; SVE-NEXT: ret
ret <16 x i8> <i8 0, i8 0, i8 127, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 0, i8 127, i8 0, i8 0, i8 0, i8 0, i8 0>
}