Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / Hexagon / brev_ld.ll
blob8cc1d0bc858e35eb06f7e133915d5bcf1bd76070
1 ; RUN: llc -march=hexagon < %s | FileCheck %s
2 ; RUN: llc -march=hexagon -verify-machineinstrs=true < %s | FileCheck %s
3 ; Testing bitreverse load intrinsics:
4 ;   Q6_bitrev_load_update_D(inputLR, pDelay, nConvLength);
5 ;   Q6_bitrev_load_update_W(inputLR, pDelay, nConvLength);
6 ;   Q6_bitrev_load_update_H(inputLR, pDelay, nConvLength);
7 ;   Q6_bitrev_load_update_UH(inputLR, pDelay, nConvLength);
8 ;   Q6_bitrev_load_update_UB(inputLR, pDelay, nConvLength);
9 ;   Q6_bitrev_load_update_B(inputLR, pDelay, nConvLength);
10 ; producing these instructions:
11 ;   r3:2 = memd(r0++m0:brev)
12 ;   r1 = memw(r0++m0:brev)
13 ;   r1 = memh(r0++m0:brev)
14 ;   r1 = memuh(r0++m0:brev)
15 ;   r1 = memub(r0++m0:brev)
16 ;   r1 = memb(r0++m0:brev)
18 target datalayout = "e-m:e-p:32:32:32-a:0-n16:32-i64:64:64-i32:32:32-i16:16:16-i1:8:8-f32:32:32-f64:64:64-v32:32:32-v64:64:64-v512:512:512-v1024:1024:1024-v2048:2048:2048"
19 target triple = "hexagon-unknown--elf"
21 ; CHECK: @call_brev_ldd
22 define ptr @call_brev_ldd(ptr %ptr, i64 %dst, i32 %mod) local_unnamed_addr #0 {
23 entry:
24 ; CHECK: = memd(r{{[0-9]*}}++m{{[0-1]}}:brev)
25   %0 = tail call { i64, ptr } @llvm.hexagon.L2.loadrd.pbr(ptr %ptr, i32 %mod)
26   %1 = extractvalue { i64, ptr } %0, 1
27   ret ptr %1
30 ; CHECK: @call_brev_ldw
31 define ptr @call_brev_ldw(ptr %ptr, i32 %dst, i32 %mod) local_unnamed_addr #0 {
32 entry:
33 ; CHECK: = memw(r{{[0-9]*}}++m{{[0-1]}}:brev)
34   %0 = tail call { i32, ptr } @llvm.hexagon.L2.loadri.pbr(ptr %ptr, i32 %mod)
35   %1 = extractvalue { i32, ptr } %0, 1
36   ret ptr %1
39 ; CHECK: @call_brev_ldh
40 define ptr @call_brev_ldh(ptr %ptr, i16 signext %dst, i32 %mod) local_unnamed_addr #0 {
41 entry:
42 ; CHECK: = memh(r{{[0-9]*}}++m{{[0-1]}}:brev)
43   %0 = tail call { i32, ptr } @llvm.hexagon.L2.loadrh.pbr(ptr %ptr, i32 %mod)
44   %1 = extractvalue { i32, ptr } %0, 1
45   ret ptr %1
48 ; CHECK: @call_brev_lduh
49 define ptr @call_brev_lduh(ptr %ptr, i16 zeroext %dst, i32 %mod) local_unnamed_addr #0 {
50 entry:
51 ; CHECK: = memuh(r{{[0-9]*}}++m{{[0-1]}}:brev)
52   %0 = tail call { i32, ptr } @llvm.hexagon.L2.loadruh.pbr(ptr %ptr, i32 %mod)
53   %1 = extractvalue { i32, ptr } %0, 1
54   ret ptr %1
57 ; CHECK: @call_brev_ldb
58 define ptr @call_brev_ldb(ptr %ptr, i8 signext %dst, i32 %mod) local_unnamed_addr #0 {
59 entry:
60 ; CHECK: = memb(r{{[0-9]*}}++m{{[0-1]}}:brev)
61   %0 = tail call { i32, ptr } @llvm.hexagon.L2.loadrb.pbr(ptr %ptr, i32 %mod)
62   %1 = extractvalue { i32, ptr } %0, 1
63   ret ptr %1
66 ; Function Attrs: nounwind readonly
67 ; CHECK: @call_brev_ldub
68 define ptr @call_brev_ldub(ptr %ptr, i8 zeroext %dst, i32 %mod) local_unnamed_addr #0 {
69 entry:
70 ; CHECK: = memub(r{{[0-9]*}}++m{{[0-1]}}:brev)
71   %0 = tail call { i32, ptr } @llvm.hexagon.L2.loadrub.pbr(ptr %ptr, i32 %mod)
72   %1 = extractvalue { i32, ptr } %0, 1
73   ret ptr %1
76 declare { i64, ptr } @llvm.hexagon.L2.loadrd.pbr(ptr, i32) #1
77 declare { i32, ptr } @llvm.hexagon.L2.loadri.pbr(ptr, i32) #1
78 declare { i32, ptr } @llvm.hexagon.L2.loadrh.pbr(ptr, i32) #1
79 declare { i32, ptr } @llvm.hexagon.L2.loadruh.pbr(ptr, i32) #1
80 declare { i32, ptr } @llvm.hexagon.L2.loadrb.pbr(ptr, i32) #1
81 declare { i32, ptr } @llvm.hexagon.L2.loadrub.pbr(ptr, i32) #1
83 attributes #0 = { nounwind readonly "target-cpu"="hexagonv60" }
84 attributes #1 = { nounwind readonly }