mirror of
https://github.com/RPCSX/llvm.git
synced 2025-01-09 21:50:38 +00:00
211 lines
5.3 KiB
LLVM
211 lines
5.3 KiB
LLVM
|
; RUN: llc < %s -mtriple=x86_64-apple-darwin -mcpu=core-avx2 -mattr=+avx2 | FileCheck %s
|
||
|
|
||
|
; CHECK: variable_shl0
|
||
|
; CHECK: psllvd
|
||
|
; CHECK: ret
|
||
|
define <4 x i32> @variable_shl0(<4 x i32> %x, <4 x i32> %y) {
|
||
|
%k = shl <4 x i32> %x, %y
|
||
|
ret <4 x i32> %k
|
||
|
}
|
||
|
; CHECK: variable_shl1
|
||
|
; CHECK: psllvd
|
||
|
; CHECK: ret
|
||
|
define <8 x i32> @variable_shl1(<8 x i32> %x, <8 x i32> %y) {
|
||
|
%k = shl <8 x i32> %x, %y
|
||
|
ret <8 x i32> %k
|
||
|
}
|
||
|
; CHECK: variable_shl2
|
||
|
; CHECK: psllvq
|
||
|
; CHECK: ret
|
||
|
define <2 x i64> @variable_shl2(<2 x i64> %x, <2 x i64> %y) {
|
||
|
%k = shl <2 x i64> %x, %y
|
||
|
ret <2 x i64> %k
|
||
|
}
|
||
|
; CHECK: variable_shl3
|
||
|
; CHECK: psllvq
|
||
|
; CHECK: ret
|
||
|
define <4 x i64> @variable_shl3(<4 x i64> %x, <4 x i64> %y) {
|
||
|
%k = shl <4 x i64> %x, %y
|
||
|
ret <4 x i64> %k
|
||
|
}
|
||
|
; CHECK: variable_srl0
|
||
|
; CHECK: psrlvd
|
||
|
; CHECK: ret
|
||
|
define <4 x i32> @variable_srl0(<4 x i32> %x, <4 x i32> %y) {
|
||
|
%k = lshr <4 x i32> %x, %y
|
||
|
ret <4 x i32> %k
|
||
|
}
|
||
|
; CHECK: variable_srl1
|
||
|
; CHECK: psrlvd
|
||
|
; CHECK: ret
|
||
|
define <8 x i32> @variable_srl1(<8 x i32> %x, <8 x i32> %y) {
|
||
|
%k = lshr <8 x i32> %x, %y
|
||
|
ret <8 x i32> %k
|
||
|
}
|
||
|
; CHECK: variable_srl2
|
||
|
; CHECK: psrlvq
|
||
|
; CHECK: ret
|
||
|
define <2 x i64> @variable_srl2(<2 x i64> %x, <2 x i64> %y) {
|
||
|
%k = lshr <2 x i64> %x, %y
|
||
|
ret <2 x i64> %k
|
||
|
}
|
||
|
; CHECK: variable_srl3
|
||
|
; CHECK: psrlvq
|
||
|
; CHECK: ret
|
||
|
define <4 x i64> @variable_srl3(<4 x i64> %x, <4 x i64> %y) {
|
||
|
%k = lshr <4 x i64> %x, %y
|
||
|
ret <4 x i64> %k
|
||
|
}
|
||
|
|
||
|
; CHECK: variable_sra0
|
||
|
; CHECK: psravd
|
||
|
; CHECK: ret
|
||
|
define <4 x i32> @variable_sra0(<4 x i32> %x, <4 x i32> %y) {
|
||
|
%k = ashr <4 x i32> %x, %y
|
||
|
ret <4 x i32> %k
|
||
|
}
|
||
|
; CHECK: variable_sra1
|
||
|
; CHECK: psravd
|
||
|
; CHECK: ret
|
||
|
define <8 x i32> @variable_sra1(<8 x i32> %x, <8 x i32> %y) {
|
||
|
%k = ashr <8 x i32> %x, %y
|
||
|
ret <8 x i32> %k
|
||
|
}
|
||
|
|
||
|
;;; Shift left
|
||
|
; CHECK: vpslld
|
||
|
define <8 x i32> @vshift00(<8 x i32> %a) nounwind readnone {
|
||
|
%s = shl <8 x i32> %a, <i32 2, i32 2, i32 2, i32 2, i32 2, i32 2, i32 2, i32
|
||
|
2>
|
||
|
ret <8 x i32> %s
|
||
|
}
|
||
|
|
||
|
; CHECK: vpsllw
|
||
|
define <16 x i16> @vshift01(<16 x i16> %a) nounwind readnone {
|
||
|
%s = shl <16 x i16> %a, <i16 2, i16 2, i16 2, i16 2, i16 2, i16 2, i16 2, i16 2, i16 2, i16 2, i16 2, i16 2, i16 2, i16 2, i16 2, i16 2>
|
||
|
ret <16 x i16> %s
|
||
|
}
|
||
|
|
||
|
; CHECK: vpsllq
|
||
|
define <4 x i64> @vshift02(<4 x i64> %a) nounwind readnone {
|
||
|
%s = shl <4 x i64> %a, <i64 2, i64 2, i64 2, i64 2>
|
||
|
ret <4 x i64> %s
|
||
|
}
|
||
|
|
||
|
;;; Logical Shift right
|
||
|
; CHECK: vpsrld
|
||
|
define <8 x i32> @vshift03(<8 x i32> %a) nounwind readnone {
|
||
|
%s = lshr <8 x i32> %a, <i32 2, i32 2, i32 2, i32 2, i32 2, i32 2, i32 2, i32
|
||
|
2>
|
||
|
ret <8 x i32> %s
|
||
|
}
|
||
|
|
||
|
; CHECK: vpsrlw
|
||
|
define <16 x i16> @vshift04(<16 x i16> %a) nounwind readnone {
|
||
|
%s = lshr <16 x i16> %a, <i16 2, i16 2, i16 2, i16 2, i16 2, i16 2, i16 2, i16 2, i16 2, i16 2, i16 2, i16 2, i16 2, i16 2, i16 2, i16 2>
|
||
|
ret <16 x i16> %s
|
||
|
}
|
||
|
|
||
|
; CHECK: vpsrlq
|
||
|
define <4 x i64> @vshift05(<4 x i64> %a) nounwind readnone {
|
||
|
%s = lshr <4 x i64> %a, <i64 2, i64 2, i64 2, i64 2>
|
||
|
ret <4 x i64> %s
|
||
|
}
|
||
|
|
||
|
;;; Arithmetic Shift right
|
||
|
; CHECK: vpsrad
|
||
|
define <8 x i32> @vshift06(<8 x i32> %a) nounwind readnone {
|
||
|
%s = ashr <8 x i32> %a, <i32 2, i32 2, i32 2, i32 2, i32 2, i32 2, i32 2, i32
|
||
|
2>
|
||
|
ret <8 x i32> %s
|
||
|
}
|
||
|
|
||
|
; CHECK: vpsraw
|
||
|
define <16 x i16> @vshift07(<16 x i16> %a) nounwind readnone {
|
||
|
%s = ashr <16 x i16> %a, <i16 2, i16 2, i16 2, i16 2, i16 2, i16 2, i16 2, i16 2, i16 2, i16 2, i16 2, i16 2, i16 2, i16 2, i16 2, i16 2>
|
||
|
ret <16 x i16> %s
|
||
|
}
|
||
|
|
||
|
; CHECK: variable_sra0_load
|
||
|
; CHECK: psravd (%
|
||
|
; CHECK: ret
|
||
|
define <4 x i32> @variable_sra0_load(<4 x i32> %x, <4 x i32>* %y) {
|
||
|
%y1 = load <4 x i32>* %y
|
||
|
%k = ashr <4 x i32> %x, %y1
|
||
|
ret <4 x i32> %k
|
||
|
}
|
||
|
|
||
|
; CHECK: variable_sra1_load
|
||
|
; CHECK: psravd (%
|
||
|
; CHECK: ret
|
||
|
define <8 x i32> @variable_sra1_load(<8 x i32> %x, <8 x i32>* %y) {
|
||
|
%y1 = load <8 x i32>* %y
|
||
|
%k = ashr <8 x i32> %x, %y1
|
||
|
ret <8 x i32> %k
|
||
|
}
|
||
|
|
||
|
; CHECK: variable_shl0_load
|
||
|
; CHECK: psllvd (%
|
||
|
; CHECK: ret
|
||
|
define <4 x i32> @variable_shl0_load(<4 x i32> %x, <4 x i32>* %y) {
|
||
|
%y1 = load <4 x i32>* %y
|
||
|
%k = shl <4 x i32> %x, %y1
|
||
|
ret <4 x i32> %k
|
||
|
}
|
||
|
; CHECK: variable_shl1_load
|
||
|
; CHECK: psllvd (%
|
||
|
; CHECK: ret
|
||
|
define <8 x i32> @variable_shl1_load(<8 x i32> %x, <8 x i32>* %y) {
|
||
|
%y1 = load <8 x i32>* %y
|
||
|
%k = shl <8 x i32> %x, %y1
|
||
|
ret <8 x i32> %k
|
||
|
}
|
||
|
; CHECK: variable_shl2_load
|
||
|
; CHECK: psllvq (%
|
||
|
; CHECK: ret
|
||
|
define <2 x i64> @variable_shl2_load(<2 x i64> %x, <2 x i64>* %y) {
|
||
|
%y1 = load <2 x i64>* %y
|
||
|
%k = shl <2 x i64> %x, %y1
|
||
|
ret <2 x i64> %k
|
||
|
}
|
||
|
; CHECK: variable_shl3_load
|
||
|
; CHECK: psllvq (%
|
||
|
; CHECK: ret
|
||
|
define <4 x i64> @variable_shl3_load(<4 x i64> %x, <4 x i64>* %y) {
|
||
|
%y1 = load <4 x i64>* %y
|
||
|
%k = shl <4 x i64> %x, %y1
|
||
|
ret <4 x i64> %k
|
||
|
}
|
||
|
; CHECK: variable_srl0_load
|
||
|
; CHECK: psrlvd (%
|
||
|
; CHECK: ret
|
||
|
define <4 x i32> @variable_srl0_load(<4 x i32> %x, <4 x i32>* %y) {
|
||
|
%y1 = load <4 x i32>* %y
|
||
|
%k = lshr <4 x i32> %x, %y1
|
||
|
ret <4 x i32> %k
|
||
|
}
|
||
|
; CHECK: variable_srl1_load
|
||
|
; CHECK: psrlvd (%
|
||
|
; CHECK: ret
|
||
|
define <8 x i32> @variable_srl1_load(<8 x i32> %x, <8 x i32>* %y) {
|
||
|
%y1 = load <8 x i32>* %y
|
||
|
%k = lshr <8 x i32> %x, %y1
|
||
|
ret <8 x i32> %k
|
||
|
}
|
||
|
; CHECK: variable_srl2_load
|
||
|
; CHECK: psrlvq (%
|
||
|
; CHECK: ret
|
||
|
define <2 x i64> @variable_srl2_load(<2 x i64> %x, <2 x i64>* %y) {
|
||
|
%y1 = load <2 x i64>* %y
|
||
|
%k = lshr <2 x i64> %x, %y1
|
||
|
ret <2 x i64> %k
|
||
|
}
|
||
|
; CHECK: variable_srl3_load
|
||
|
; CHECK: psrlvq (%
|
||
|
; CHECK: ret
|
||
|
define <4 x i64> @variable_srl3_load(<4 x i64> %x, <4 x i64>* %y) {
|
||
|
%y1 = load <4 x i64>* %y
|
||
|
%k = lshr <4 x i64> %x, %y1
|
||
|
ret <4 x i64> %k
|
||
|
}
|