[llvm-readelf/llvm-objdump] - Improve/refactor the implementation of SHT_LLVM_ADDRSIG...
[llvm-complete.git] / test / CodeGen / Hexagon / memset-inline.ll
blob4a77e24f39c6455c9fe7b546efcbe8ee83d87a40
1 ; RUN: llc -march=hexagon -O2 < %s | FileCheck %s
3 target triple = "hexagon-unknown--elf"
5 ; Test to see if we inline memsets when the array size is small.
6 ; CHECK-LABEL: f0
7 ; CHECK-DAG: memw
8 ; CHECK-DAG: memb
9 ; CHECK-DAG: memh
10 define i32 @f0() #0 {
11 b0:
12   %v0 = alloca [10 x i32], align 8
13   %v1 = bitcast [10 x i32]* %v0 to i8*
14   call void @llvm.memset.p0i8.i32(i8* align 8 %v1, i8 0, i32 7, i1 false)
15   %v2 = getelementptr inbounds [10 x i32], [10 x i32]* %v0, i32 0, i32 0
16   call void @f1(i32* %v2) #0
17   ret i32 0
20 ; Function Attrs: nounwind
21 declare void @f1(i32*) #0
23 ; Function Attrs: argmemonly nounwind
24 declare void @llvm.memset.p0i8.i32(i8* nocapture writeonly, i8, i32, i1) #1
26 attributes #0 = { nounwind }
27 attributes #1 = { argmemonly nounwind }