Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / ARM / cache-intrinsic.ll
blob571ce568a926e9a29c6d6003c22645ec80732213
1 ; RUN: llc %s -o - | FileCheck %s
2 target datalayout = "e-m:e-p:32:32-i64:64-v128:64:128-n32-S64"
3 target triple = "armv7--linux-gnueabihf"
5 @buffer = global [32 x i8] c"This is a largely unused buffer\00", align 1
6 @.str = private unnamed_addr constant [4 x i8] c"%s\0A\00", align 1
7 @.str1 = private unnamed_addr constant [25 x i8] c"Still, largely unused...\00", align 1
9 define i32 @main() {
10 entry:
11   %retval = alloca i32, align 4
12   store i32 0, ptr %retval
13   %call = call i32 (ptr, ...) @printf(ptr @.str, ptr @buffer)
14   %call1 = call ptr @strcpy(ptr @buffer, ptr @.str1) #3
15   call void @llvm.clear_cache(ptr @buffer, ptr getelementptr inbounds (i8, ptr @buffer, i32 32)) #3
16   %call2 = call i32 (ptr, ...) @printf(ptr @.str, ptr @buffer)
17   ret i32 0
20 ; CHECK: __clear_cache
22 declare i32 @printf(ptr, ...)
24 declare ptr @strcpy(ptr, ptr)
26 declare void @llvm.clear_cache(ptr, ptr)