[ARM] Adjust how NEON shifts are lowered
[llvm-core.git] / test / Instrumentation / SanitizerCoverage / backedge-pruning.ll
blob5e9e579e1712016f505ba8d0a22aaaa03a52e759
1 ; Test -sanitizer-coverage-trace-compares=1 and how it prunes backedge compares.
2 ; RUN: opt < %s -sancov -sanitizer-coverage-level=1 -sanitizer-coverage-trace-compares=1  -sanitizer-coverage-prune-blocks=1 -S | FileCheck %s --check-prefix=PRUNE
3 ; RUN: opt < %s -sancov -sanitizer-coverage-level=1 -sanitizer-coverage-trace-compares=1  -sanitizer-coverage-prune-blocks=0 -S | FileCheck %s --check-prefix=NOPRUNE
4 ; RUN: opt < %s -passes='module(sancov-module),function(sancov-func)' -sanitizer-coverage-level=1 -sanitizer-coverage-trace-compares=1  -sanitizer-coverage-prune-blocks=1 -S | FileCheck %s --check-prefix=PRUNE
5 ; RUN: opt < %s -passes='module(sancov-module),function(sancov-func)' -sanitizer-coverage-level=1 -sanitizer-coverage-trace-compares=1  -sanitizer-coverage-prune-blocks=0 -S | FileCheck %s --check-prefix=NOPRUNE
7 target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64"
8 target triple = "x86_64-unknown-linux-gnu"
10 define dso_local void @foo(i32* nocapture readnone %a, i32 %n) local_unnamed_addr {
11 entry:
12   br label %do.body
14 do.body:
15   %i.0 = phi i32 [ 0, %entry ], [ %inc, %do.body ]
16   tail call void (...) @bar()
17   %inc = add nuw nsw i32 %i.0, 1
18   %cmp = icmp slt i32 %inc, %n
19 ;PRUNE-LABEL: foo
20 ;PRUNE-NOT: __sanitizer_cov_trace_cmp4
21 ;PRUNE: ret void
23 ;NOPRUNE-LABEL: foo
24 ;NOPRUNE: call void @__sanitizer_cov_trace_cmp4
25 ;NOPRUNE-NEXT: icmp
26 ;NOPRUNE: ret void
28   br i1 %cmp, label %do.body, label %do.end
30 do.end:
31   ret void
34 declare dso_local void @bar(...) local_unnamed_addr