Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / ARC / intrinsics.ll
blob873a911281c4aaff3134b0286fe3ef5e8820301c
1 ; RUN: llc -march=arc < %s | FileCheck %s
3 target triple = "arc"
5 declare i32 @llvm.ctlz.i32(i32, i1)
6 declare i32 @llvm.cttz.i32(i32, i1)
7 declare i64 @llvm.readcyclecounter()
9 ; CHECK-LABEL: test_ctlz_i32:
10 ; CHECK:       fls.f   %r0, %r0
11 ; CHECK-NEXT:  mov.eq  %r0, 32
12 ; CHECK-NEXT:  rsub.ne %r0, %r0, 31
13 define i32 @test_ctlz_i32(i32 %x) {
14   %a = call i32 @llvm.ctlz.i32(i32 %x, i1 false)
15   ret i32 %a
18 ; CHECK-LABEL: test_cttz_i32:
19 ; CHECK:       ffs.f   %r0, %r0
20 ; CHECK-NEXT:  mov.eq  %r0, 32
21 define i32 @test_cttz_i32(i32 %x) {
22   %a = call i32 @llvm.cttz.i32(i32 %x, i1 false)
23   ret i32 %a
26 ; CHECK-LABEL: test_readcyclecounter:
27 ; CHECK:       lr %r0, [33]
28 ; CHECK-NEXT:  mov %r1, 0
29 define i64 @test_readcyclecounter() nounwind {
30   %a = call i64 @llvm.readcyclecounter()
31   ret i64 %a