[ARM] Split large truncating MVE stores
[llvm-complete.git] / test / Transforms / InstCombine / call-intrinsics.ll
blob1f327b99e9cbf23b6a3755c87a87bacfd2fda34e
1 ; RUN: opt < %s -instcombine | llvm-dis
3 @X = global i8 0                ; <i8*> [#uses=3]
4 @Y = global i8 12               ; <i8*> [#uses=2]
6 declare void @llvm.memmove.p0i8.p0i8.i32(i8*, i8*, i32, i1)
8 declare void @llvm.memcpy.p0i8.p0i8.i32(i8*, i8*, i32, i1)
10 declare void @llvm.memset.p0i8.i32(i8*, i8, i32, i1)
12 define void @zero_byte_test() {
13         ; These process zero bytes, so they are a noop.
14         call void @llvm.memmove.p0i8.p0i8.i32(i8* align 128 @X, i8* align 128 @Y, i32 0, i1 false )
15         call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 128 @X, i8* align 128 @Y, i32 0, i1 false )
16         call void @llvm.memset.p0i8.i32(i8* align 128 @X, i8 123, i32 0, i1 false )
17         ret void