blob: 4db8ced58327a7f999bc0ba37aa00335b3b29ba8 [file] [edit]
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 6
; bswap should be constant folded when it is passed a constant argument
; RUN: opt < %s -passes=instsimplify -S | FileCheck %s
; RUN: opt < %s -passes=instsimplify -use-constant-int-for-fixed-length-splat -use-constant-int-for-scalable-splat -S | FileCheck %s
declare i16 @llvm.bswap.i16(i16)
declare i32 @llvm.bswap.i32(i32)
declare i64 @llvm.bswap.i64(i64)
declare i80 @llvm.bswap.i80(i80)
define i16 @W() {
; CHECK-LABEL: define i16 @W() {
; CHECK-NEXT: ret i16 256
;
%Z = call i16 @llvm.bswap.i16( i16 1 ) ; <i16> [#uses=1]
ret i16 %Z
}
define i32 @X() {
; CHECK-LABEL: define i32 @X() {
; CHECK-NEXT: ret i32 16777216
;
%Z = call i32 @llvm.bswap.i32( i32 1 ) ; <i32> [#uses=1]
ret i32 %Z
}
define i64 @Y() {
; CHECK-LABEL: define i64 @Y() {
; CHECK-NEXT: ret i64 72057594037927936
;
%Z = call i64 @llvm.bswap.i64( i64 1 ) ; <i64> [#uses=1]
ret i64 %Z
}
define i80 @Z() {
; CHECK-LABEL: define i80 @Z() {
; CHECK-NEXT: ret i80 -450681596205739728166896
;
%Z = call i80 @llvm.bswap.i80( i80 76151636403560493650080 )
ret i80 %Z
}
define <4 x i32> @bswap_splat_v4i32() {
; CHECK-LABEL: define <4 x i32> @bswap_splat_v4i32() {
; CHECK-NEXT: ret <4 x i32> splat (i32 16777216)
;
%Z = call <4 x i32> @llvm.bswap.v4i32(<4 x i32> splat(i32 1))
ret <4 x i32> %Z
}
define <vscale x 4 x i32> @bswap_splat_nxv4i32() {
; CHECK-LABEL: define <vscale x 4 x i32> @bswap_splat_nxv4i32() {
; CHECK-NEXT: ret <vscale x 4 x i32> splat (i32 16777216)
;
%Z = call <vscale x 4 x i32> @llvm.bswap.v4i32(<vscale x 4 x i32> splat(i32 1))
ret <vscale x 4 x i32> %Z
}